diff --git a/src/test_tools/vm_interact/narsese_expectation.rs b/src/test_tools/vm_interact/narsese_expectation.rs index 2a4578f..ca7f179 100644 --- a/src/test_tools/vm_interact/narsese_expectation.rs +++ b/src/test_tools/vm_interact/narsese_expectation.rs @@ -222,15 +222,16 @@ fn is_expected_truth( out: &EnumTruth, precision_epoch: FloatPrecision, ) -> bool { - match (expected, out) { + use EnumTruth::*; + match [expected, out] { // 预期空真值⇒通配 - (EnumTruth::Empty, ..) => true, + [Empty, ..] => true, // 预期单真值⇒部分通配 - (EnumTruth::Single(f_e), EnumTruth::Single(f_o) | EnumTruth::Double(f_o, ..)) => { + [Single(f_e), Single(f_o) | Double(f_o, ..)] => { is_expected_float(f_e, f_o, precision_epoch) } // 预期双真值 - (EnumTruth::Double(f_e, c_e), EnumTruth::Double(f_o, c_o)) => { + [Double(f_e, c_e), Double(f_o, c_o)] => { is_expected_float(f_e, f_o, precision_epoch) && is_expected_float(c_e, c_o, precision_epoch) } @@ -247,24 +248,21 @@ fn is_expected_budget( out: &EnumBudget, precision_epoch: FloatPrecision, ) -> bool { - match (expected, out) { + use EnumBudget::*; + match [expected, out] { // 预期空预算⇒通配 - (EnumBudget::Empty, ..) => true, + [Empty, ..] => true, // 预期单预算 - ( - EnumBudget::Single(p_e), - EnumBudget::Single(p_o) | EnumBudget::Double(p_o, ..) | EnumBudget::Triple(p_o, ..), - ) => is_expected_float(p_e, p_o, precision_epoch), + [Single(p_e), Single(p_o) | Double(p_o, ..) | Triple(p_o, ..)] => { + is_expected_float(p_e, p_o, precision_epoch) + } // 预期双预算 - ( - EnumBudget::Double(p_e, d_e), - EnumBudget::Double(p_o, d_o) | EnumBudget::Triple(p_o, d_o, ..), - ) => { + [Double(p_e, d_e), Double(p_o, d_o) | Triple(p_o, d_o, ..)] => { is_expected_float(p_e, p_o, precision_epoch) && is_expected_float(d_e, d_o, precision_epoch) } // 预期三预算 - (EnumBudget::Triple(p_e, d_e, q_e), EnumBudget::Triple(p_o, d_o, q_o)) => { + [Triple(p_e, d_e, q_e), Triple(p_o, d_o, q_o)] => { is_expected_float(p_e, p_o, precision_epoch) && is_expected_float(d_e, d_o, precision_epoch) && is_expected_float(q_e, q_o, precision_epoch) @@ -281,13 +279,13 @@ pub fn is_expected_operation(expected: &Operation, out: &Operation) -> bool { if_return! { expected.operator_name != out.operator_name => false } // 比对操作参数:先判空 - match (expected.no_params(), out.no_params()) { + match [expected.no_params(), out.no_params()] { // 预期无⇒通配 - (true, ..) => true, + [true, ..] => true, // 预期有,输出无⇒直接pass - (false, true) => false, + [false, true] => false, // 预期有,输出有⇒判断参数是否相同 - (false, false) => expected.params == out.params, + [false, false] => expected.params == out.params, } } @@ -303,78 +301,96 @@ mod tests { fn test(expected: Narsese, out: Narsese, precision_epoch: FloatPrecision) { assert!( super::is_expected_narsese_lexical(&expected, &out, precision_epoch), - "正例断言失败!\nexpected: {expected:?}, out: {out:?}" + "正例断言失败!\nexpected: {expected:?}\nout: {out:?}\nprecision_epoch: {precision_epoch:?}" ); } /// 反例断言带精度 fn test_negative(expected: Narsese, out: Narsese, precision_epoch: FloatPrecision) { assert!( !super::is_expected_narsese_lexical(&expected, &out, precision_epoch), - "反例断言失败!\nexpected: {expected:?}, out: {out:?}" + "反例断言失败!\nexpected: {expected:?}\nout: {out:?}\nprecision_epoch: {precision_epoch:?}" ); } // * 🚩正例 macro_once! { macro test { ( // 分派&展开 - $($expected:literal ==$config:tt== $out:literal $(,)?)* + $($expected:literal $op:tt $config:tt => $out:literal $(,)?)* ) => { $( - test!(@SPECIFIC $expected, $out, $config); + test!(@SPECIFIC $expected, $out, $op, $config); )* } - ( // 正例 + ( // * 📝正例语法:"预期" ==(精度)=> "输出" @SPECIFIC $expected:literal, $out:literal, - {$epoch:literal} + ==, + ($epoch:expr) ) => { test(nse!($expected), nse!($out), $epoch) } - ( // 反例 + ( // * 📝反例语法:"预期" !=(精度)=> "输出" @SPECIFIC $expected:literal, $out:literal, - {! $epoch:literal} + !=, + ($epoch:expr) ) => { test_negative(nse!($expected), nse!($out), $epoch) } } // * 🚩正例 // 常规词项、语句、任务 - "A" =={0.0}== "A", - "A." =={0.0}== "A.", - "A?" =={0.0}== "A?", - "A! %1.0;0.9%" =={0.0}== "A! %1.0;0.9%" - "$0.5;0.5;0.5$ A@" =={0.0}== "$0.5;0.5;0.5$ A@", - "$0.5;0.5;0.5$ A. %1.0;0.9%" =={0.0}== "$0.5;0.5;0.5$ A. %1.0;0.9%", - // 真值通配 - "A." =={0.0}== "A. %1.0;0.9%", - "A!" =={0.0}== "A! %1.0;0.9%", - // 预算值通配 - "A." =={0.0}== "$0.5;0.5;0.5$ A.", - "A!" =={0.0}== "$0.5;0.5;0.5$ A!", - "A." =={0.0}== "$0.5;0.5;0.5$ A. %1.0;0.9%", - "A!" =={0.0}== "$0.5;0.5;0.5$ A! %1.0;0.9%", - // TODO: 真值精度内匹配 - // TODO: 预算值精度内匹配 - // 源自实际应用 - "<(&&,<$1 --> lock>,<$2 --> key>) ==> <$1 --> (/,open,$2,_)>>. %1.00;0.45%" - =={0.0}== "<(&&,<$1 --> key>,<$2 --> lock>) ==> <$2 --> (/,open,$1,_)>>. %1.00;0.45%" - // * 🚩反例 - "A" =={!0.0}== "B", - "A." =={!0.0}== "A?", - "A?" =={!0.0}== " B>?", + "A" ==(0.0)=> "A", + "A" !=(0.0)=> "B", + "A." ==(0.0)=> "A.", + "A." !=(0.0)=> "A?", + "A?" ==(0.0)=> "A?", + "A?" !=(0.0)=> " B>?", + "A! %1.0;0.9%" ==(0.0)=> "A! %1.0;0.9%" + "$0.5;0.5;0.5$ A@" ==(0.0)=> "$0.5;0.5;0.5$ A@", + "$0.5;0.5;0.5$ A. %1.0;0.9%" ==(0.0)=> "$0.5;0.5;0.5$ A. %1.0;0.9%", // 真值通配(反向就不行) - "A. %1.0;0.9%" =={!0.0}== "A.", - "A! %1.0;0.9%" =={!0.0}== "A!", + "A." ==(0.0)=> "A. %1.0;0.9%", + "A!" ==(0.0)=> "A! %1.0;0.9%", + "A. %1.0;0.9%" !=(0.0)=> "A.", + "A! %1.0;0.9%" !=(0.0)=> "A!", // 预算值通配(反向就不行) - "$0.5;0.5;0.5$ A." =={!0.0}== "A.", - "$0.5;0.5;0.5$ A!" =={!0.0}== "A!", - "$0.5;0.5;0.5$ A. %1.0;0.9%" =={!0.0}== "A.", - "$0.5;0.5;0.5$ A! %1.0;0.9%" =={!0.0}== "A!", - // TODO: 真值精度内失配 - // TODO: 预算值精度内失配 + "A." ==(0.0)=> "$0.5;0.5;0.5$ A.", + "A!" ==(0.0)=> "$0.5;0.5;0.5$ A!", + "A." ==(0.0)=> "$0.5;0.5;0.5$ A. %1.0;0.9%", + "A!" ==(0.0)=> "$0.5;0.5;0.5$ A! %1.0;0.9%", + "$0.5;0.5;0.5$ A." !=(0.0)=> "A.", + "$0.5;0.5;0.5$ A!" !=(0.0)=> "A!", + "$0.5;0.5;0.5$ A. %1.0;0.9%" !=(0.0)=> "A.", + "$0.5;0.5;0.5$ A! %1.0;0.9%" !=(0.0)=> "A!", + // 真值精度内匹配 + "A. %0.5;0.9%" ==(0.00)=> "A. %0.5;0.9%", + "A. %0.5;0.9%" ==(0.10)=> "A. %0.55;0.95%", // +0.10 + "A. %0.5;0.9%" ==(0.10)=> "A. %0.45;0.85%", // -0.10 + "A. %0.5;0.9%" ==(0.10)=> "A. %0.55;0.85%", // ±0.10 + "A. %0.5;0.9%" !=(0.01)=> "A. %0.55;0.85%", // ±0.01 + "A. %0.5%" ==(0.1)=> "A. %0.55;0.85%", // +通配 + "A. %0.5%" !=(-0.1)=> "A. %0.5%", // 负数永不匹配 + "A. %0;1%" ==(FloatPrecision::INFINITY)=> "A. %1;0%", // 正无穷总是匹配 + "A. %0.5%" !=(FloatPrecision::NEG_INFINITY)=> "A. %0.5%", // 负无穷永不匹配 + // 预算值精度内匹配 + "$0.5;0.7;0.9$ A." ==(0.0)=> "$0.5;0.7;0.9$ A.", + "$0.5;0.9$ A." ==(0.051)=> "$0.55;0.85$ A.", // ±0.05,通配,防止极限`0.050000000000000044`情形 + "$0.5;0.9$ A." !=(0.051)=> "$0.55;0.84$ A.", // ±0.05,通配,防止极限`0.050000000000000044`情形 + "$0.5;0.9$ A." !=(0.051)=> "$0.55;0.96$ A.", // ±0.05,通配,防止极限`0.050000000000000044`情形 + "$0.5;0.7;0.9$ A." ==(0.051)=> "$0.55;0.7058;0.85$ A.", // ±0.050,防止极限`0.050000000000000044`情形 + "$0.5;0.7;0.9$ A." !=(0.041)=> "$0.55;0.7058;0.85$ A.", // ±0.040,防止极限`0.050000000000000044`情形 + "$0.5;0.7;0.9$ A." ==(0.041)=> "$0.54;0.7058;0.86$ A.", // ±0.040,防止极限`0.050000000000000044`情形 + "$0.5;0.7;0.9$ A." !=(0.001)=> "$0.55;0.7058;0.85$ A.", // ±0.001,防止极限`0.050000000000000044`情形 + // 源自实际应用 + "<(&&,<$1 --> lock>,<$2 --> key>) ==> <$1 --> (/,open,$2,_)>>. %1.00;0.45%" + ==(0.0)=> "<(&&,<$1 --> key>,<$2 --> lock>) ==> <$2 --> (/,open,$1,_)>>. %1.00;0.45%" + " robin>. %1.00;0.45%" // 四位⇒两位(位数不一,但值相同) + ==(0.01)=> "$0.9944;0.7848;0.7238$ robin>. %1.0000;0.4500%", + " bird>. %1.00;0.47%" // 四位⇒两位(位数不一,精度不同) + ==(0.01)=> "$0.8333;0.7200;0.7369$ bird>. %1.0000;0.4737%", } }