From 5f92c9895d393a512f85fbb553f31314f3fd2d12 Mon Sep 17 00:00:00 2001 From: ARCJ137442 <61109168+ARCJ137442@users.noreply.github.com> Date: Sun, 14 Apr 2024 20:42:07 +0800 Subject: [PATCH 1/4] =?UTF-8?q?test:=20:white=5Fcheck=5Fmark:=20=E4=BD=BF?= =?UTF-8?q?=E7=94=A8=E5=B1=9E=E6=80=A7=E5=AE=8F=E3=80=8Cignore=E3=80=8D?= =?UTF-8?q?=E5=BF=BD=E7=95=A5=E9=83=A8=E5=88=86=E3=80=90=E4=B8=8D=E5=AE=9C?= =?UTF-8?q?=E5=8F=82=E4=B8=8E=E6=95=B4=E4=BD=93=E6=B5=8B=E8=AF=95=E3=80=91?= =?UTF-8?q?=E7=9A=84=E6=B5=8B=E8=AF=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ①忽略所有「整体测试后留下残余子进程」的测试(OpenNARS、NARS-Python)②忽略Websocket相关、仅用于快捷运行的「持续性压力测试」 --- Cargo.lock | 2 +- Cargo.toml | 2 +- src/bin/babelnar_cli/arg_parse.rs | 1 + src/bin/babelnar_cli/main.rs | 6 +++++- src/bin/ws_server_test/main.rs | 2 ++ src/cin_implements/nars_python/mod.rs | 1 + src/cin_implements/openjunars/mod.rs | 1 + src/cin_implements/opennars/mod.rs | 2 ++ src/runtimes/command_vm/runtime.rs | 1 + 9 files changed, 15 insertions(+), 3 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 683bb1b..ffbda46 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -73,7 +73,7 @@ checksum = "f1fdabc7756949593fe60f30ec81974b613357de856987752631dea1e3394c80" [[package]] name = "babel_nar" -version = "0.21.0" +version = "0.21.1" dependencies = [ "anyhow", "clap", diff --git a/Cargo.toml b/Cargo.toml index 0204430..91555a7 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "babel_nar" -version = "0.21.0" +version = "0.21.1" edition = "2021" description = """ Implementation and application supports of the NAVM model diff --git a/src/bin/babelnar_cli/arg_parse.rs b/src/bin/babelnar_cli/arg_parse.rs index 2270b28..9517db6 100644 --- a/src/bin/babelnar_cli/arg_parse.rs +++ b/src/bin/babelnar_cli/arg_parse.rs @@ -158,6 +158,7 @@ mod tests { /// 测试/成功的解析 #[test] + #[ignore = "【2024-04-14 20:24:52】会导致残留子进程"] fn test_arg_parse() { test_arg_parse! { ["-c", ARG_PARSE_TEST] diff --git a/src/bin/babelnar_cli/main.rs b/src/bin/babelnar_cli/main.rs index bfb6c5f..f460ff7 100644 --- a/src/bin/babelnar_cli/main.rs +++ b/src/bin/babelnar_cli/main.rs @@ -146,7 +146,8 @@ mod tests { /// 批量生成「预引入NAL」 macro_rules! cin_tests { ( - $cin_path:expr; + $(#[$attr_root:meta])* + $cin_path:ident; // ! ❌若为`expr`,则会和上边的修饰符导致「本地歧义」 $( $(#[$attr:meta])* $name:ident => $config_path:expr $(;)? @@ -155,6 +156,7 @@ mod tests { /// 主Shell /// * 🎯正常BabelNAR CLI shell启动 /// * 🎯正常用户命令行交互体验 + $(#[$attr_root])* #[test] pub fn main_shell() -> Result<()> { main($cin_path, &[]) @@ -163,6 +165,7 @@ mod tests { /// Matriangle服务器 /// * 🎯复现先前基于Matriangle环境的NARS实验 + $(#[$attr_root])* #[test] pub fn main_matriangle_server() -> Result<()> { // 以默认参数启动 @@ -219,6 +222,7 @@ mod tests { use super::*; cin_tests! { + #[ignore = "【2024-04-14 20:24:52】会导致残留子进程"] OPENNARS; /// 简单演绎 diff --git a/src/bin/ws_server_test/main.rs b/src/bin/ws_server_test/main.rs index 52c0ccd..faa0381 100644 --- a/src/bin/ws_server_test/main.rs +++ b/src/bin/ws_server_test/main.rs @@ -99,6 +99,7 @@ fn main() { } #[test] +#[ignore = "【2024-04-14 20:38:45】仅作为其它Websocket服务端的压力测试,不应在库测试中出现"] fn test_overwhelming_nse() { loop { let _ = ws::connect("ws://127.0.0.1:8765", |sender| { @@ -123,6 +124,7 @@ fn test_overwhelming_nse() { /// 压力测试 /// * 🔗GitHub issue: #[test] +#[ignore = "【2024-04-14 20:38:45】仅作为其它Websocket服务端的压力测试,不应在库测试中出现"] fn main_server() { // A client that sends tons of messages to the server thread::spawn(move || { diff --git a/src/cin_implements/nars_python/mod.rs b/src/cin_implements/nars_python/mod.rs index 469211c..0184be9 100644 --- a/src/cin_implements/nars_python/mod.rs +++ b/src/cin_implements/nars_python/mod.rs @@ -24,6 +24,7 @@ mod tests { }; #[test] + #[ignore = "【2024-04-14 20:24:52】会导致残留子进程"] fn test() { // 从别的地方获取exe路径 let exe_path = NARS_PYTHON; diff --git a/src/cin_implements/openjunars/mod.rs b/src/cin_implements/openjunars/mod.rs index 7804c79..9dc4383 100644 --- a/src/cin_implements/openjunars/mod.rs +++ b/src/cin_implements/openjunars/mod.rs @@ -24,6 +24,7 @@ mod tests { }; #[test] + #[ignore = "【2024-04-14 20:24:52】会导致残留子进程"] fn test() { // 从别的地方获取jl路径 let jl_path = OPENJUNARS; diff --git a/src/cin_implements/opennars/mod.rs b/src/cin_implements/opennars/mod.rs index dd2d9b1..2f4aaf6 100644 --- a/src/cin_implements/opennars/mod.rs +++ b/src/cin_implements/opennars/mod.rs @@ -35,6 +35,7 @@ mod tests { /// 测试 #[test] + #[ignore = "【2024-04-14 20:24:52】会导致残留子进程"] fn test() { // 启动OpenNARS虚拟机 let vm = launch_vm(); @@ -44,6 +45,7 @@ mod tests { /// 测试/通用 | 基于Narsese #[test] + #[ignore = "【2024-04-14 20:24:52】会导致残留子进程"] fn test_universal() { // 启动OpenNARS虚拟机 let vm = launch_vm(); diff --git a/src/runtimes/command_vm/runtime.rs b/src/runtimes/command_vm/runtime.rs index 17d4574..c7dd048 100644 --- a/src/runtimes/command_vm/runtime.rs +++ b/src/runtimes/command_vm/runtime.rs @@ -359,6 +359,7 @@ pub mod tests { /// 示例测试 | OpenNARS /// * 🚩通过Java命令启动 #[test] + #[ignore = "【2024-04-14 20:24:52】会导致残留子进程"] fn test_opennars() { // 构造指令 let mut command_java = Command::new(COMMAND_JAVA); From 6bb800e93f06498590ebf1a8edf67d8a8be80f71 Mon Sep 17 00:00:00 2001 From: ARCJ137442 <61109168+ARCJ137442@users.noreply.github.com> Date: Fri, 19 Apr 2024 13:46:06 +0800 Subject: [PATCH 2/4] =?UTF-8?q?test:=20:white=5Fcheck=5Fmark:=20=E6=B5=8B?= =?UTF-8?q?=E8=AF=95=E6=94=AF=E6=8C=81OpenNARS=201.5.8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 添加对定制版OpenNARS 1.5.8的测试支持,包括配置和测试代码;更新测试文件,加入延迟以等待OpenNARS 1.5.8输出 --- Cargo.lock | 2 +- Cargo.toml | 2 +- src/bin/babelnar_cli/main.rs | 38 +++++++++++++++++++-- src/lib.rs | 2 ++ src/tests/cli/config/cin_opennars.hjson | 3 +- src/tests/cli/config/cin_opennars_158.hjson | 23 +++++++++++++ src/tests/nal/test_higher_deduction.nal | 3 ++ src/tests/nal/test_i_var_elimination.nal | 3 ++ src/tests/nal/test_simple_deduction.nal | 3 ++ 9 files changed, 73 insertions(+), 6 deletions(-) create mode 100644 src/tests/cli/config/cin_opennars_158.hjson diff --git a/Cargo.lock b/Cargo.lock index ffbda46..83efc08 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -73,7 +73,7 @@ checksum = "f1fdabc7756949593fe60f30ec81974b613357de856987752631dea1e3394c80" [[package]] name = "babel_nar" -version = "0.21.1" +version = "0.21.2" dependencies = [ "anyhow", "clap", diff --git a/Cargo.toml b/Cargo.toml index 91555a7..eb08b51 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "babel_nar" -version = "0.21.1" +version = "0.21.2" edition = "2021" description = """ Implementation and application supports of the NAVM model diff --git a/src/bin/babelnar_cli/main.rs b/src/bin/babelnar_cli/main.rs index f460ff7..7ed854a 100644 --- a/src/bin/babelnar_cli/main.rs +++ b/src/bin/babelnar_cli/main.rs @@ -190,7 +190,7 @@ mod tests { ONA; /// 简单演绎 - /// * 📝✅【2024-04-07 14:56:04】成功 + /// * 📝✅【2024-04-19 13:28:21】成功 nal_de => NAL_SIMPLE_DEDUCTION /// 高阶演绎 @@ -217,7 +217,7 @@ mod tests { } } - /// 测试/OpenNARS + /// 测试/OpenNARS (3.x) mod opennars { use super::*; @@ -251,6 +251,40 @@ mod tests { } } + /// 测试/OpenNARS (1.5.8) + mod opennars158 { + use super::*; + + cin_tests! { + #[ignore = "【2024-04-14 20:24:52】会导致残留子进程"] + OPENNARS_158; + + /// 简单演绎 + /// * 📝✅【2024-04-19 13:28:27】成功 + nal_de => NAL_SIMPLE_DEDUCTION + + /// 高阶演绎 + /// * 📝✅【2024-04-19 13:39:16】成功 + nal_hi => NAL_HIGHER_DEDUCTION + + /// 自变量消除 + /// * 📝✅【2024-04-19 13:39:23】成功 + nal_ie => NAL_I_VAR_ELIMINATION + + /// 时间归纳 + /// * 📝❌【2024-04-19 13:30:25】失败:语法层面就不支持 + nal_te => NAL_TEMPORAL_INDUCTION + + /// 简单操作 + /// * 📝❌【2024-04-19 13:30:25】失败:没有任何输出 + nal_so => NAL_SIMPLE_OPERATION + + /// 操作 + /// * 📝❌【2024-04-19 13:30:25】失败:语法层面就不支持 + nal_op => NAL_OPERATION + } + } + /// 测试/PyNARS mod pynars { use super::*; diff --git a/src/lib.rs b/src/lib.rs index 498173d..592a638 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -68,6 +68,8 @@ pub mod tests { /// OpenNARS OPENNARS = "./src/tests/cli/config/cin_opennars.hjson" + /// OpenNARS + OPENNARS_158 = "./src/tests/cli/config/cin_opennars_158.hjson" /// ONA ONA = "./src/tests/cli/config/cin_ona.hjson" /// PyNARS diff --git a/src/tests/cli/config/cin_opennars.hjson b/src/tests/cli/config/cin_opennars.hjson index cad8431..bde0b8d 100644 --- a/src/tests/cli/config/cin_opennars.hjson +++ b/src/tests/cli/config/cin_opennars.hjson @@ -1,6 +1,5 @@ #hjson -// * 📌包含OpenNARS转译器 及其jar启动的命令配置 -// * 🎯用于测试「预加载NAL输入」,加载「简单演绎推理」 +// OpenNARS 3.0.4 的启动配置 { // 转译器 translators: "opennars" diff --git a/src/tests/cli/config/cin_opennars_158.hjson b/src/tests/cli/config/cin_opennars_158.hjson new file mode 100644 index 0000000..abeb52e --- /dev/null +++ b/src/tests/cli/config/cin_opennars_158.hjson @@ -0,0 +1,23 @@ +#hjson +// OpenNARS 1.5.8 的启动配置 +{ + // 转译器 + translators: "opennars" + // 启动命令 + command: { + // 命令:启动java运行时 + cmd: "java" + // 传入的命令参数 + cmdArgs: [ + // 设置最大堆内存为1024M + "-Xmx1024m" + // 启动jar包 + -jar + ./opennars-158-shell.jar + ] + // 启动时的工作目录 + // * 🚩现在基于「固定位置的CIN程序包」运行测试 + // * 回溯路径:config(`./`) => cli => tests => src => BabelNAR.rs / executables + currentDir: ./../../../../executables + } +} \ No newline at end of file diff --git a/src/tests/nal/test_higher_deduction.nal b/src/tests/nal/test_higher_deduction.nal index a73a549..e2088f8 100644 --- a/src/tests/nal/test_higher_deduction.nal +++ b/src/tests/nal/test_higher_deduction.nal @@ -20,8 +20,11 @@ < B> ==> D>>. ' // ''await: IN < B> ==> D>>. +''sleep: 0.05s +' * 🚩【2024-04-19 13:28:46】增加睡眠时间,以让OpenNARS 158、CXinNARS有时间输出 B>. ' // ''await: IN B>. +''sleep: 0.05s D>? 5 diff --git a/src/tests/nal/test_i_var_elimination.nal b/src/tests/nal/test_i_var_elimination.nal index 9552984..8c8a246 100644 --- a/src/tests/nal/test_i_var_elimination.nal +++ b/src/tests/nal/test_i_var_elimination.nal @@ -14,7 +14,10 @@ ''sleep: 0.5s B>. +''sleep: 0.05s +' * 🚩【2024-04-19 13:28:46】增加睡眠时间,以让OpenNARS 158、CXinNARS有时间输出 < $1> ==> <$1 --> C>>. +''sleep: 0.05s C>? 100 diff --git a/src/tests/nal/test_simple_deduction.nal b/src/tests/nal/test_simple_deduction.nal index 878ae4a..ca8ab2c 100644 --- a/src/tests/nal/test_simple_deduction.nal +++ b/src/tests/nal/test_simple_deduction.nal @@ -20,8 +20,11 @@ B>. ' // ''await: IN B>. +''sleep: 0.05s +' * 🚩【2024-04-19 13:28:46】增加睡眠时间,以让OpenNARS 158、CXinNARS有时间输出 C>. ' // ''await: IN C>. +''sleep: 0.05s C>? 5 From 2ce701fd16565b47e3a6a204a9c3358051a41e67 Mon Sep 17 00:00:00 2001 From: ARCJ137442 <61109168+ARCJ137442@users.noreply.github.com> Date: Fri, 19 Apr 2024 23:13:07 +0800 Subject: [PATCH 3/4] =?UTF-8?q?feat:=20:sparkles:=20=E5=AF=B9NAL=E6=A0=BC?= =?UTF-8?q?=E5=BC=8F=E6=96=B0=E5=A2=9E=E3=80=8C=E5=BE=AA=E7=8E=AF=E7=AD=89?= =?UTF-8?q?=E5=BE=85=E9=A2=84=E6=9C=9F=E3=80=8D=E5=8A=9F=E8=83=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 增强自动化测试功能:加入「循环等待预期」魔法注释,允许「每批循环一定步数、等待并检查预期,超过指定步数未有『符合预期之输出』⇒报错」的灵活测试逻辑 --- Cargo.lock | 2 +- Cargo.toml | 2 +- src/bin/babelnar_cli/main.rs | 61 ++++++++++---------- src/test_tools/nal_format/mod.rs | 66 ++++++++++++++++++---- src/test_tools/nal_format/nal_grammar.pest | 16 +++++- src/test_tools/structs.rs | 9 +++ src/test_tools/vm_interact.rs | 33 ++++++++++- src/tests/nal/test_higher_deduction.nal | 11 +--- src/tests/nal/test_i_var_elimination.nal | 11 +--- src/tests/nal/test_operation.nal | 18 +++--- src/tests/nal/test_simple_deduction.nal | 12 ++-- src/tests/nal/test_simple_operation.nal | 15 ++--- src/tests/nal/test_temporal_induction.nal | 8 +-- 13 files changed, 171 insertions(+), 93 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 83efc08..c12f517 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -73,7 +73,7 @@ checksum = "f1fdabc7756949593fe60f30ec81974b613357de856987752631dea1e3394c80" [[package]] name = "babel_nar" -version = "0.21.2" +version = "0.22.0" dependencies = [ "anyhow", "clap", diff --git a/Cargo.toml b/Cargo.toml index eb08b51..5d6369d 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "babel_nar" -version = "0.21.2" +version = "0.22.0" edition = "2021" description = """ Implementation and application supports of the NAVM model diff --git a/src/bin/babelnar_cli/main.rs b/src/bin/babelnar_cli/main.rs index 7ed854a..f7efa08 100644 --- a/src/bin/babelnar_cli/main.rs +++ b/src/bin/babelnar_cli/main.rs @@ -100,6 +100,7 @@ pub fn main_args(cwd: IoResult, args: impl Iterator) -> /// 单元测试 #[cfg(test)] +#[allow(unused_attributes)] mod tests { use super::*; use babel_nar::tests::config_paths::*; @@ -158,6 +159,7 @@ mod tests { /// * 🎯正常用户命令行交互体验 $(#[$attr_root])* #[test] + #[ignore = "仅作试运行用,不用于自动化测试"] pub fn main_shell() -> Result<()> { main($cin_path, &[]) } @@ -167,6 +169,7 @@ mod tests { /// * 🎯复现先前基于Matriangle环境的NARS实验 $(#[$attr_root])* #[test] + #[ignore = "仅作试运行用,不用于自动化测试"] pub fn main_matriangle_server() -> Result<()> { // 以默认参数启动 main_configs($cin_path, &[MATRIANGLE_SERVER]) @@ -190,27 +193,27 @@ mod tests { ONA; /// 简单演绎 - /// * 📝✅【2024-04-19 13:28:21】成功 + /// * 📝✅【2024-04-19 22:49:51】成功 nal_de => NAL_SIMPLE_DEDUCTION /// 高阶演绎 - /// * 📝✅【2024-04-07 14:56:04】成功 + /// * 📝✅【2024-04-19 22:50:04】成功 nal_hi => NAL_HIGHER_DEDUCTION /// 自变量消除 - /// * 📝✅【2024-04-07 16:03:47】成功 + /// * 📝✅【2024-04-19 22:50:53】成功 nal_ie => NAL_I_VAR_ELIMINATION /// 时间归纳 - /// * 📝✅【2024-04-07 15:22:28】成功 + /// * 📝✅【2024-04-19 22:52:45】成功 nal_te => NAL_TEMPORAL_INDUCTION /// 简单操作 - /// * 📝❌【2024-04-07 16:15:53】失败:推理不出任何内容 + /// * 📝❌【2024-04-19 22:55:35】失败:推理不出任何内容 nal_so => NAL_SIMPLE_OPERATION /// 操作 - /// * 📝✅【2024-04-07 14:57:50】成功,但少许问题 + /// * 📝✅【2024-04-19 23:01:52】成功,但少许问题 /// * 📝【2024-04-07 14:17:21】目前ONA面对其中的「经验问句」没有回答 /// * ⚠️在启用`REG left`注册操作后,反而从成功变为失败 nal_op => NAL_OPERATION @@ -226,11 +229,11 @@ mod tests { OPENNARS; /// 简单演绎 - /// * 📝✅【2024-04-07 14:59:37】成功 + /// * 📝✅【2024-04-19 22:49:02】成功(步数性能上不佳) nal_de => NAL_SIMPLE_DEDUCTION /// 高阶演绎 - /// * 📝✅【2024-04-07 14:59:44】成功 + /// * 📝✅【2024-04-19 22:48:56】成功 nal_hi => NAL_HIGHER_DEDUCTION /// 自变量消除 @@ -238,7 +241,7 @@ mod tests { nal_ie => NAL_I_VAR_ELIMINATION /// 时间归纳 - /// * 📝✅【2024-04-07 15:22:28】成功 + /// * 📝✅【2024-04-19 22:52:35】成功(步数性能上不佳) nal_te => NAL_TEMPORAL_INDUCTION /// 简单操作 @@ -260,27 +263,27 @@ mod tests { OPENNARS_158; /// 简单演绎 - /// * 📝✅【2024-04-19 13:28:27】成功 + /// * 📝✅【2024-04-19 23:02:59】成功 nal_de => NAL_SIMPLE_DEDUCTION /// 高阶演绎 - /// * 📝✅【2024-04-19 13:39:16】成功 + /// * 📝✅【2024-04-19 23:03:06】成功 nal_hi => NAL_HIGHER_DEDUCTION /// 自变量消除 - /// * 📝✅【2024-04-19 13:39:23】成功 + /// * 📝✅【2024-04-19 23:03:15】成功 nal_ie => NAL_I_VAR_ELIMINATION /// 时间归纳 - /// * 📝❌【2024-04-19 13:30:25】失败:语法层面就不支持 + /// * 📝❌【2024-04-19 23:03:20】失败:语法层面就不支持 nal_te => NAL_TEMPORAL_INDUCTION /// 简单操作 - /// * 📝❌【2024-04-19 13:30:25】失败:没有任何输出 + /// * 📝❌【2024-04-19 23:03:37】失败:语法层面就不支持 nal_so => NAL_SIMPLE_OPERATION /// 操作 - /// * 📝❌【2024-04-19 13:30:25】失败:语法层面就不支持 + /// * 📝❌【2024-04-19 23:03:48】失败:语法层面就不支持 nal_op => NAL_OPERATION } } @@ -293,27 +296,28 @@ mod tests { PYNARS; /// 简单演绎 - /// * 📝✅【2024-04-07 17:11:22】成功 + /// * 📝✅【2024-04-19 23:04:24】成功 nal_de => NAL_SIMPLE_DEDUCTION /// 高阶演绎 - /// * 📝✅【2024-04-07 17:11:36】成功 + /// * 📝✅【2024-04-19 23:04:33】成功 nal_hi => NAL_HIGHER_DEDUCTION /// 自变量消除 - /// * 📝❌【2024-04-07 16:01:15】失败:啥推理都没有 + /// * 📝❌【2024-04-19 23:05:32】失败:啥推理都没有 nal_ie => NAL_I_VAR_ELIMINATION /// 时间归纳 - /// * 📝❌【2024-04-07 16:13:52】失败:只会回答`D>. :\: %1.000;0.900%` + /// * 📝❌【2024-04-19 23:06:43】失败:只会回答`D>. :\: %1.000;0.900%` nal_te => NAL_TEMPORAL_INDUCTION /// 简单操作 - /// * 📝❌【2024-04-07 16:13:42】失败:没有任何回答 + /// * 📝❌【2024-04-19 23:06:48】失败:没有任何回答 nal_so => NAL_SIMPLE_OPERATION /// 操作 - /// * 📝❌【2024-04-07 14:39:49】目前仍测试失败 + /// * 📝❌【2024-04-19 23:07:11】目前仍测试失败 + /// * 📄【2024-04-19 23:07:27】只会回答`ANSWER:<{SELF}-->(/, ^left, _)>. :\: %1.000;0.900%` /// * 📌PyNARS自身对NAL-7、NAL-8支持尚不完善 /// * 📌PyNARS中操作`left`并非默认已注册 /// * ❌【2024-04-07 14:41:54】补充:追加了也不行 @@ -322,6 +326,7 @@ mod tests { } /// 测试/CXinJS + /// * 📝【2024-04-19 23:10:28】用来试探「自动测试脚本」的下限 mod cxin_js { use super::*; @@ -330,31 +335,29 @@ mod tests { /// 简单演绎 /// * 📝❌【2024-04-07 14:37:49】失败:导出了结论,但没法回答 + /// * 📄只能导出`C>. %1;0.9%` nal_de => NAL_SIMPLE_DEDUCTION /// 高阶演绎 - /// * 📝❌【2024-04-07 14:37:49】失败:只能导出到`B>?` + /// * 📝❌【2024-04-19 23:08:44】失败:只能导出到`B>?` /// * 📌即便是五百步,也推不出来 nal_hi => NAL_HIGHER_DEDUCTION /// 自变量消除 - /// * 📝❌【2024-04-07 16:01:15】失败:仅推理到`C>?`,并且遇到「XXX is not a function」错误 + /// * 📝❌【2024-04-19 23:09:21】失败:仅推理到`C>?`,并且遇到「XXX is not a function」错误 nal_ie => NAL_I_VAR_ELIMINATION /// 时间归纳 - /// * 📝❌失败:解析即报错——不支持`=/>` + /// * 📝❌【2024-04-19 23:09:34】失败:解析即报错——不支持`=/>` nal_te => NAL_TEMPORAL_INDUCTION /// 简单操作 - /// * 📝❌【2024-04-07 16:16:24】失败:推理不出任何内容 + /// * 📝❌【2024-04-19 23:09:47】失败:推理不出任何内容 /// * 💭还会把「目标」解析成「判断」…… nal_so => NAL_SIMPLE_OPERATION /// 操作 - /// * 📝❌目前仍测试失败 - /// * 📌PyNARS自身对NAL-7、NAL-8支持尚不完善 - /// * 📌PyNARS中操作`left`并非默认已注册 - /// * 📝❌【2024-04-07 14:37:49】失败:自身就不支持 + /// * 📝❌【2024-04-19 23:10:21】失败:自身就不支持 nal_op => NAL_OPERATION } } diff --git a/src/test_tools/nal_format/mod.rs b/src/test_tools/nal_format/mod.rs index f9698fb..6212357 100644 --- a/src/test_tools/nal_format/mod.rs +++ b/src/test_tools/nal_format/mod.rs @@ -104,16 +104,7 @@ fn fold_pest(pair: Pair) -> Result { // 取其中第一个`comment_raw`元素 | 一定只有唯一一个`comment_raw` let duration_raw = pair.into_inner().next().unwrap().as_str().trim(); // 尝试解析时间 - let duration = first! { - // 毫秒→微秒→纳秒→秒 | 对于「秒」分「整数」「浮点」两种 - duration_raw.ends_with("ms") => Duration::from_millis(duration_raw.strip_suffix("ms").unwrap().parse()?), - duration_raw.ends_with("μs") => Duration::from_micros(duration_raw.strip_suffix("μs").unwrap().parse()?), - duration_raw.ends_with("ns") => Duration::from_nanos(duration_raw.strip_suffix("ns").unwrap().parse()?), - duration_raw.ends_with('s') && duration_raw.contains('.') => Duration::try_from_secs_f64(duration_raw.strip_suffix('s').unwrap().parse()?)?, - duration_raw.ends_with('s') => Duration::from_secs(duration_raw.strip_suffix('s').unwrap().parse()?), - // 否则报错 - _ => return Err(anyhow::anyhow!("未知的睡眠时间参数 {duration_raw:?}")) - }; + let duration = parse_duration(duration_raw)?; // * 封装 let input = NALInput::Sleep(duration); Ok(input) @@ -138,6 +129,48 @@ fn fold_pest(pair: Pair) -> Result { let file_path = pair.into_inner().next().unwrap().as_str().into(); Ok(NALInput::SaveOutputs(file_path)) } + // 魔法注释/循环预期 + Rule::comment_expect_cycle => { + let mut pairs = pair.into_inner(); + // 取其中的「最大步数」 + let max_cycles = pipe! { + pairs.next().unwrap() + => .as_str() + => {.parse::()}# + => {?}# + }; + // 取其中的「每次步长」 + let step_cycles = pipe! { + pairs.next().unwrap() + => .as_str() + => {.parse::()}# + => {?}# + }; + // 取其中的「输出预期」 + let step_duration = pairs.next(); + let step_duration = match step_duration { + Some(step_duration) => { + // 尝试解析时间 + let step_duration = parse_duration(step_duration.as_str())?; + // 封装 + Some(step_duration) + } + None => None, + }; + // 取其中的「输出预期」 + let output_expectation = pipe! { + pairs.next().unwrap() + => fold_pest_output_expectation + => {?}# + }; + // 构造 & 返回 + Ok(NALInput::ExpectCycle( + max_cycles, + step_cycles, + step_duration, + output_expectation, + )) + } // 魔法注释/终止 Rule::comment_terminate => { // 预置默认值 @@ -250,6 +283,19 @@ fn fold_pest_output_operation(pair: Pair) -> Result { }) } +fn parse_duration(duration_raw: &str) -> Result { + Ok(first! { + // 毫秒→微秒→纳秒→秒 | 对于「秒」分「整数」「浮点」两种 + duration_raw.ends_with("ms") => Duration::from_millis(duration_raw.strip_suffix("ms").unwrap().parse()?), + duration_raw.ends_with("μs") => Duration::from_micros(duration_raw.strip_suffix("μs").unwrap().parse()?), + duration_raw.ends_with("ns") => Duration::from_nanos(duration_raw.strip_suffix("ns").unwrap().parse()?), + duration_raw.ends_with('s') && duration_raw.contains('.') => Duration::try_from_secs_f64(duration_raw.strip_suffix('s').unwrap().parse()?)?, + duration_raw.ends_with('s') => Duration::from_secs(duration_raw.strip_suffix('s').unwrap().parse()?), + // 否则报错 + _ => return Err(anyhow::anyhow!("未知的睡眠时间参数 {duration_raw:?}")) + }) +} + /// 单元测试 #[cfg(test)] pub mod tests { diff --git a/src/test_tools/nal_format/nal_grammar.pest b/src/test_tools/nal_format/nal_grammar.pest index fcfe616..5c77157 100644 --- a/src/test_tools/nal_format/nal_grammar.pest +++ b/src/test_tools/nal_format/nal_grammar.pest @@ -29,7 +29,7 @@ cyc_uint = { ASCII_DIGIT+ } /// 注释(静默) /// * 🚩包括「输出预期」等「魔法注释」 comment = _{ - comment_head ~ (comment_navm_cmd | comment_sleep | comment_await | comment_expect_contains | comment_save_outputs | comment_terminate | comment_raw) + comment_head ~ (comment_navm_cmd | comment_sleep | comment_await | comment_expect_contains | comment_save_outputs | comment_expect_cycle | comment_terminate | comment_raw) } /// 注释的头部字符(静默) @@ -76,6 +76,20 @@ comment_save_outputs = { "'save-outputs:" ~ output_expectation } +/// 有关「循环等待预期」的「魔法注释」 +/// ✨阻塞主线程,循环指定周期,并在其中检查预期; +/// * 每步进「步长」个周期后,检查NAVM输出预期,有⇒终止,打印输出`expect-cycle(【次数】): 【输出】` +/// * 检查后,若存在时间,则等待指定时间 +/// * 若循环后仍无,上报「预期不符」 +comment_expect_cycle = { + // 额外的前缀 + "'expect-cycle" ~ "(" ~ cyc_uint ~ "," ~ cyc_uint ~ ("," ~ comment_expect_cycle_step_time)? ~ "):" ~ output_expectation +} + +/// 「循环等待预期」中的「每步后等待时间」 +/// * 🎯解决「输入CIN后,CIN输出需要时间,来不及反应」的问题 +comment_expect_cycle_step_time = { (!")" ~ !"," ~ ANY)* } + /// 有关「终止」的「魔法注释」 /// ✨终止NAVM虚拟机 /// * 📄参数:选项、理由 diff --git a/src/test_tools/structs.rs b/src/test_tools/structs.rs index 1243232..f959b99 100644 --- a/src/test_tools/structs.rs +++ b/src/test_tools/structs.rs @@ -35,6 +35,15 @@ pub enum NALInput { /// * 📄对应OpenNARS中常有的`''outputMustContain('')` ExpectContains(OutputExpectation), + /// 对「输出含有」的循环预期 + /// * 📄语法示例:`''expect-cycle(500, 10, 0.1s): ANSWER C>.` + /// * 🎯用于「在『最大步数』的限定下循环尝试获取『期望的输出』,未获得预期输出⇒预期失败」 + /// * 🚩循环指定周期(最大步数),并在其中检查预期; + /// * 每步进1周期后,检查NAVM输出预期,有⇒终止,打印输出`expect-cycle(【次数】): 【输出】` + /// * 若循环后仍无,视作「预期不符」 + /// * 📄在「最大步数=0」的情形之下,`expect-cycle(0)`等价于[`expect-contains`](NALInput::ExpectContains) + ExpectCycle(usize, usize, Option, OutputExpectation), + /// 保存「输出缓存」到指定文件 /// * 📄语法示例:`''save-outputs: outputs.log` /// * 🎯用于「将现有所有输出以『NAVM输出的JSON格式』存档至指定文件中」 diff --git a/src/test_tools/vm_interact.rs b/src/test_tools/vm_interact.rs index 561f6ca..4ee02c2 100644 --- a/src/test_tools/vm_interact.rs +++ b/src/test_tools/vm_interact.rs @@ -2,12 +2,12 @@ use std::{ops::ControlFlow, path::Path}; -use crate::cli_support::error_handling_boost::error_anyhow; +use crate::cli_support::{error_handling_boost::error_anyhow, io::output_print::OutputType}; use super::{NALInput, OutputExpectation, OutputExpectationError}; use anyhow::Result; use nar_dev_utils::{if_return, ResultBoost}; -use navm::{output::Output, vm::VmRuntime}; +use navm::{cmd::Cmd, output::Output, vm::VmRuntime}; /// * 🎯统一存放与「Narsese预期识别」有关的代码 /// * 🚩【2024-04-02 22:49:12】从[`crate::runtimes::command_vm::runtime::tests`]中迁移而来 @@ -266,6 +266,35 @@ pub fn put_nal( // } // } } + // 检查在指定的「最大步数」内,是否有NAVM输出符合预期(弹性步数`0~最大步数`) + NALInput::ExpectCycle(max_cycles, step_cycles, step_duration, expectation) => { + let mut cycles = 0; + while cycles < max_cycles { + // 推理步进 + vm.input_cmd(Cmd::CYC(step_cycles))?; + cycles += step_cycles; + // 等待指定时长 + if let Some(duration) = step_duration { + std::thread::sleep(duration); + } + // 先尝试拉取所有输出到「输出缓存」 + while let Some(output) = vm.try_fetch_output()? { + output_cache.put(output)?; + } + // 然后读取并匹配缓存 + let result = output_cache.for_each(|output| match expectation.matches(output) { + true => ControlFlow::Break(true), + false => ControlFlow::Continue(()), + })?; + // 匹配到一个⇒提前返回Ok + if let Some(true) = result { + OutputType::Info.print_line(&format!("expect-cycle({cycles}): {expectation}")); + return Ok(()); + } + } + // 步进完所有步数,仍未有匹配⇒返回Err + Err(OutputExpectationError::ExpectedNotExists(expectation).into()) + } // 保存(所有)输出 // * 🚩输出到一个文本文件中 // * ✨复合JSON「对象数组」格式 diff --git a/src/tests/nal/test_higher_deduction.nal b/src/tests/nal/test_higher_deduction.nal index e2088f8..ad22c56 100644 --- a/src/tests/nal/test_higher_deduction.nal +++ b/src/tests/nal/test_higher_deduction.nal @@ -20,19 +20,14 @@ < B> ==> D>>. ' // ''await: IN < B> ==> D>>. -''sleep: 0.05s -' * 🚩【2024-04-19 13:28:46】增加睡眠时间,以让OpenNARS 158、CXinNARS有时间输出 B>. ' // ''await: IN B>. -''sleep: 0.05s D>? -5 - -' 使用睡眠延时,给足输出呈现时间 -''sleep: 1s ' 检验输出 -''expect-contains: ANSWER D>. +''expect-cycle(100, 10, 0.25s): ANSWER D>. +' * 🚩【2024-04-19 21:45:12】↑OpenNARS 3.x引入了大量心理操作,因此在「逐步递进」测试中性能不佳 +' * 📝【2024-04-19 21:46:42】OpenNARS 158、ONA、PyNARS等均能在五步之内回答 ' 用户无法输入时退出(正常退出) ''terminate(if-no-user) diff --git a/src/tests/nal/test_i_var_elimination.nal b/src/tests/nal/test_i_var_elimination.nal index 8c8a246..defa381 100644 --- a/src/tests/nal/test_i_var_elimination.nal +++ b/src/tests/nal/test_i_var_elimination.nal @@ -14,18 +14,11 @@ ''sleep: 0.5s B>. -''sleep: 0.05s -' * 🚩【2024-04-19 13:28:46】增加睡眠时间,以让OpenNARS 158、CXinNARS有时间输出 < $1> ==> <$1 --> C>>. -''sleep: 0.05s C>? -100 -' 使用睡眠延时,给足输出呈现时间 -''sleep: 1s - -' 检验输出 -''expect-contains: ANSWER C>. +' 检验输出 | ⚠️0.25s需要兼容PyNARS +''expect-cycle(200, 20, 0.25s): ANSWER C>. ' 用户无法输入时退出(正常退出) ''terminate(if-no-user) diff --git a/src/tests/nal/test_operation.nal b/src/tests/nal/test_operation.nal index dfb2cd5..01283d2 100644 --- a/src/tests/nal/test_operation.nal +++ b/src/tests/nal/test_operation.nal @@ -30,9 +30,9 @@ G. :|: <(&/, A, <(*, {SELF}) --> ^left>) ==> G>? A. :|: G! :|: -10 -''sleep: 1s -''expect-contains: EXE (^left, {SELF}) +''expect-cycle(2000, 200, 0.2s): EXE (^left, {SELF}) +' * 🚩【2024-04-19 21:45:12】↑OpenNARS 3.x引入了大量心理操作,因此在「逐步递进」测试中性能不佳 +' * 📝【2024-04-19 21:46:42】OpenNARS 158、ONA、PyNARS等均能在5步之内回答 A2. :|: <(*, {SELF}, P) --> ^left>. :|: @@ -42,9 +42,9 @@ G2. :|: <(&/, A2, <(*, {SELF}, P) --> ^left>) ==> G2>? A2. :|: G2! :|: -10 -''sleep: 1s -''expect-contains: EXE (^left, {SELF}, P) +''expect-cycle(2000, 200, 0.2s): EXE (^left, {SELF}, P) +' * 🚩【2024-04-19 21:45:12】↑OpenNARS 3.x引入了大量心理操作,因此在「逐步递进」测试中性能不佳 +' * 📝【2024-04-19 21:46:42】OpenNARS 158、ONA、PyNARS等均能在5步之内回答 A3. :|: <(*, {SELF}, (*, P1, P2)) --> ^left>. :|: @@ -54,9 +54,9 @@ G3. :|: <(&/, A3, <(*, {SELF}, (*, P1, P2)) --> ^left>) ==> G3>? A3. :|: G3! :|: -10 -''sleep: 1s -''expect-contains: EXE (^left, {SELF}, (*, P1, P2)) +''expect-cycle(2000, 200, 0.2s): EXE (^left, {SELF}, (*, P1, P2)) +' * 🚩【2024-04-19 21:45:12】↑OpenNARS 3.x引入了大量心理操作,因此在「逐步递进」测试中性能不佳 +' * 📝【2024-04-19 21:46:42】OpenNARS 158、ONA、PyNARS等均能在5步之内回答 ''sleep: 500ms diff --git a/src/tests/nal/test_simple_deduction.nal b/src/tests/nal/test_simple_deduction.nal index ca8ab2c..b581637 100644 --- a/src/tests/nal/test_simple_deduction.nal +++ b/src/tests/nal/test_simple_deduction.nal @@ -20,19 +20,15 @@ B>. ' // ''await: IN B>. -''sleep: 0.05s ' * 🚩【2024-04-19 13:28:46】增加睡眠时间,以让OpenNARS 158、CXinNARS有时间输出 C>. ' // ''await: IN C>. -''sleep: 0.05s C>? -5 -' 使用睡眠延时,给足输出呈现时间 -''sleep: 1s - -' 检验输出 -''expect-contains: ANSWER C>. +' 检验输出 | 每10步有0.25s睡眠延时,给足输出呈现时间 +''expect-cycle(100, 10, 0.25s): ANSWER C>. +' * 🚩【2024-04-19 21:45:12】↑OpenNARS 3.x引入了大量心理操作,因此在「逐步递进」测试中性能不佳 +' * 📝【2024-04-19 21:46:42】OpenNARS 158、ONA、PyNARS等均能在五步之内回答 ' 用户无法输入时退出(正常退出) ''terminate(if-no-user) diff --git a/src/tests/nal/test_simple_operation.nal b/src/tests/nal/test_simple_operation.nal index 2999a2b..3b6c851 100644 --- a/src/tests/nal/test_simple_operation.nal +++ b/src/tests/nal/test_simple_operation.nal @@ -19,19 +19,16 @@ ' '/REG left <(*, {SELF}) --> ^left>! :|: -10 -''sleep: 1s -''expect-contains: EXE (^left, {SELF}) +' * 🚩一次性执行一百步(并延时等待),若无预期输出⇒上报 +''expect-cycle(100, 100, 0.25s): EXE (^left, {SELF}) <(*, {SELF}, P) --> ^left>! :|: -10 -''sleep: 1s -''expect-contains: EXE (^left, {SELF}, P) +' * 🚩一次性执行一百步(并延时等待),若无预期输出⇒上报 +''expect-cycle(100, 100, 0.25s): EXE (^left, {SELF}, P) <(*, {SELF}, (*, P1, P2)) --> ^left>! :|: -10 -''sleep: 1s -''expect-contains: EXE (^left, {SELF}, (*, P1, P2)) +' * 🚩一次性执行一百步(并延时等待),若无预期输出⇒上报 +''expect-cycle(100, 100, 0.25s): EXE (^left, {SELF}, (*, P1, P2)) ''sleep: 500ms ''terminate(if-no-user) diff --git a/src/tests/nal/test_temporal_induction.nal b/src/tests/nal/test_temporal_induction.nal index cdec7ee..86bd533 100644 --- a/src/tests/nal/test_temporal_induction.nal +++ b/src/tests/nal/test_temporal_induction.nal @@ -28,13 +28,9 @@ < B> =/> D>>? -5 - -' 使用睡眠延时,给足输出呈现时间 -''sleep: 1s - ' 检验输出 -''expect-contains: ANSWER < B> =/> D>>. +''expect-cycle(500, 50, 0.25s): ANSWER < B> =/> D>>. +' * 🚩【2024-04-19 21:45:12】↑OpenNARS 3.x引入了大量心理操作,因此在「逐步递进」测试中性能不佳 ' 用户无法输入时退出(正常退出) ''terminate(if-no-user) From b787f18de9db8f9ab7ffff47f673025c1e31fc57 Mon Sep 17 00:00:00 2001 From: ARCJ137442 <61109168+ARCJ137442@users.noreply.github.com> Date: Fri, 19 Apr 2024 23:41:16 +0800 Subject: [PATCH 4/4] =?UTF-8?q?ci:=20:sparkles:=20=E6=B7=BB=E5=8A=A0?= =?UTF-8?q?=E5=BF=AB=E9=80=9F=E6=9E=84=E5=BB=BA=E8=84=9A=E6=9C=AC=EF=BC=8C?= =?UTF-8?q?=E9=99=84=E5=B8=A6=E5=8F=91=E8=A1=8C=E7=89=88=E9=85=8D=E7=BD=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 现在可通过运行build.bat直接从源码构建「发行版CLI」到dist目录下 --- .gitignore | 2 ++ build.bat | 31 ++++++++++++++++++++++++++++ config_public/cin_cxin_js.hjson | 24 +++++++++++++++++++++ config_public/cin_native_il_1.hjson | 15 ++++++++++++++ config_public/cin_ona.hjson | 20 ++++++++++++++++++ config_public/cin_opennars.hjson | 26 +++++++++++++++++++++++ config_public/cin_opennars_158.hjson | 26 +++++++++++++++++++++++ config_public/cin_pynars.hjson | 21 +++++++++++++++++++ 8 files changed, 165 insertions(+) create mode 100644 build.bat create mode 100644 config_public/cin_cxin_js.hjson create mode 100644 config_public/cin_native_il_1.hjson create mode 100644 config_public/cin_ona.hjson create mode 100644 config_public/cin_opennars.hjson create mode 100644 config_public/cin_opennars_158.hjson create mode 100644 config_public/cin_pynars.hjson diff --git a/.gitignore b/.gitignore index 1720687..92fa8f0 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,6 @@ +# 目标文件/可分发文件 /target +/dist # 可执行文件 # * 🚩【2024-04-07 08:42:13】目前内置被忽略的CIN可执行文件,用于稳定的测试代码编写 diff --git a/build.bat b/build.bat new file mode 100644 index 0000000..c59d83b --- /dev/null +++ b/build.bat @@ -0,0 +1,31 @@ +@REM BabelNAR CLI 轻量级发行版 +@REM * 将BabelNAR CLI、预设好的可执行文件和指定CIN集成在一个目录下 +@REM * 可实现「一次打包,到处解压,双击运行」 +@echo off + +@REM 构建BabelNAR CLI(基于cargo) +cargo b -r --bin babelnar_cli + +@REM 重置dist文件夹 +rm -rf dist +mkdir .\dist + +@REM ==拷贝各个文件到指定目录== REM@ + +@REM 公共配置 +xcopy /E /I .\config_public .\dist\nars_config + +@REM 拷贝BabelNAR CLI +copy .\target\release\babelnar_cli.exe .\dist + +@REM 拷贝指定的可执行文件 +xcopy /E /I .\executables\PyNARS .\dist\executables\PyNARS +copy .\executables\cxin-nars-shell.js .\dist\executables\cxin-nars-shell.js +copy .\executables\native-IL-1.exe .\dist\executables\native-IL-1.exe +copy .\executables\ONA.exe .\dist\executables\ONA.exe +copy .\executables\opennars-158-shell.jar .\dist\executables\opennars-158-shell.jar +copy .\executables\opennars-304-T-modified.jar .\dist\executables\opennars-304-T-modified.jar +copy .\executables\opennars-matriangle-test.log.json .\dist\executables\opennars-matriangle-test.log.json + +echo "Build Successfull!" +sleep 1 diff --git a/config_public/cin_cxin_js.hjson b/config_public/cin_cxin_js.hjson new file mode 100644 index 0000000..d68a7ca --- /dev/null +++ b/config_public/cin_cxin_js.hjson @@ -0,0 +1,24 @@ +#hjson +// CXin JS +// * 🎯配置启动CXinNARS +// * @Author 孙常新 +// * ⚠️需要Node.js启动 +// * 🔗中文官网:https://nodejs.org/zh-cn +{ + description: "CXinNARS(基于Node.js运行时,从源码启动)" + // 输入输出转译器 + translators: "cxin_js" + // 启动命令 + command: { + // * ⚠️必须前缀`./`以指定是「启动当前工作目录下的exe文件」 + cmd: node + cmdArgs: [ + cxin-nars-shell.js + shell + ] + // 启动目录 + currentDir: ./../executables + } + // 自动重启 + autoRestart: true +} \ No newline at end of file diff --git a/config_public/cin_native_il_1.hjson b/config_public/cin_native_il_1.hjson new file mode 100644 index 0000000..e1753f1 --- /dev/null +++ b/config_public/cin_native_il_1.hjson @@ -0,0 +1,15 @@ +#hjson +// * 🎯用于测试原生「IL-1」运行时 +// * ✨基于NAVM,纯Rust编写 +{ + description: Native IL-1(基于NAVM的独立exe,使用纯Rust编写) + translators: native + command: { + // * ⚠️必须前缀`./`以指定是「启动当前工作目录下的exe文件」 + cmd: ./native-IL-1.exe + cmdArgs: [] + // 启动目录 + currentDir: ./../executables + } + autoRestart: true +} \ No newline at end of file diff --git a/config_public/cin_ona.hjson b/config_public/cin_ona.hjson new file mode 100644 index 0000000..c484571 --- /dev/null +++ b/config_public/cin_ona.hjson @@ -0,0 +1,20 @@ +#hjson +// ONA +// * 🎯配置启动ONA +// * 🔗官网:https://github.com/opennars/OpenNARS-for-Applications +// * ⚠️启动需要cygwin +// * 🔗中文官网: http://www.cygwin.cn/ +{ + description: ONA (OpenNARS for Applications)(独立exe,需要cygwin) + translators: ona + command: { + // * ⚠️必须前缀`./`以指定是「启动当前工作目录下的exe文件」 + cmd: ./ONA.exe + cmdArgs: [ + shell + ] + // 启动目录 + currentDir: ./../executables + } + autoRestart: true +} \ No newline at end of file diff --git a/config_public/cin_opennars.hjson b/config_public/cin_opennars.hjson new file mode 100644 index 0000000..efc604d --- /dev/null +++ b/config_public/cin_opennars.hjson @@ -0,0 +1,26 @@ +#hjson +// OpenNARS +// * 🎯配置启动OpenNARS +// * 🔗官网:http://www.opennars.org/ +// * ⚠️需要Java启动 +// * 🔗中文官网:https://www.java.com/zh_CN/ +{ + description: "OpenNARS(jar文件,需要Java运行时JRE)" + // 转译器 + translators: "opennars" + // 启动命令 + command: { + // 命令:启动java运行时 + cmd: "java" + // 传入的命令参数 + cmdArgs: [ + // 启动jar包 + -jar + ./opennars-304-T-modified.jar + ] + // 启动目录 + currentDir: ./../executables + } + // 自动重启 + autoRestart: true +} \ No newline at end of file diff --git a/config_public/cin_opennars_158.hjson b/config_public/cin_opennars_158.hjson new file mode 100644 index 0000000..58cc720 --- /dev/null +++ b/config_public/cin_opennars_158.hjson @@ -0,0 +1,26 @@ +#hjson +// OpenNARS +// * 🎯配置启动OpenNARS +// * 🔗官网:https://github.com/patham9/opennars_declarative_core +// * ⚠️需要Java启动 +// * 🔗中文官网:https://www.java.com/zh_CN/ +{ + description: "OpenNARS 1.5.8(jar文件,需要Java运行时JRE)" + // 转译器 + translators: "opennars" + // 启动命令 + command: { + // 命令:启动java运行时 + cmd: "java" + // 传入的命令参数 + cmdArgs: [ + // 启动jar包 + -jar + ./opennars-158-shell.jar + ] + // 启动目录 + currentDir: ./../executables + } + // 自动重启 + autoRestart: true +} \ No newline at end of file diff --git a/config_public/cin_pynars.hjson b/config_public/cin_pynars.hjson new file mode 100644 index 0000000..b0a7380 --- /dev/null +++ b/config_public/cin_pynars.hjson @@ -0,0 +1,21 @@ +// PyNARS +// * 🎯配置启动PyNARS +// * 🔗官网:https://github.com/bowen-xu/PyNARS +// * ⚠️需要Python(从源码)启动 +// * 🔗官网:http://python.org/ +// * ℹ️推荐版本:3.10+ +{ + description: PyNARS(基于Python运行时,从源码启动) + translators: pynars + command: { + cmd: python + cmdArgs: [ + "-m" + // * 🚩【2024-04-07 14:41:20】使用扩展了「附加指令」的「高级控制台」 + pynars.ConsolePlus + ] + // 启动目录 + currentDir: ./../executables/PyNARS + } + autoRestart: true +} \ No newline at end of file