runmat-runtime 0.4.1

Core runtime for RunMat with builtins, BLAS/LAPACK integration, and execution APIs
Documentation
#[cfg(target_arch = "wasm32")]
wasm_bindgen_test::wasm_bindgen_test_configure!(run_in_browser);
use runmat_builtins::{Tensor, Value};
use runmat_runtime::elementwise_neg;

#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test::wasm_bindgen_test)]
#[test]
fn test_scalar_negation() {
    // Test numeric scalar
    let num = Value::Num(42.0);
    let result = elementwise_neg(&num).unwrap();
    assert_eq!(result, Value::Num(-42.0));

    // Test integer scalar
    let int = Value::Int(runmat_builtins::IntValue::I32(5));
    let result = elementwise_neg(&int).unwrap();
    assert_eq!(result, Value::Int(runmat_builtins::IntValue::I32(-5)));

    // Test boolean scalar
    let bool_val = Value::Bool(true);
    let result = elementwise_neg(&bool_val).unwrap();
    assert_eq!(result, Value::Bool(false));
}

#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test::wasm_bindgen_test)]
#[test]
fn test_matrix_negation() {
    // Test 2x2 matrix
    let matrix = Tensor::new_2d(vec![1.0, 2.0, 3.0, 4.0], 2, 2).unwrap();
    let value = Value::Tensor(matrix);
    let result = elementwise_neg(&value).unwrap();

    if let Value::Tensor(result_matrix) = result {
        assert_eq!(result_matrix.data, vec![-1.0, -2.0, -3.0, -4.0]);
        assert_eq!(result_matrix.rows(), 2);
        assert_eq!(result_matrix.cols(), 2);
    } else {
        panic!("Expected matrix result");
    }
}

#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test::wasm_bindgen_test)]
#[test]
fn test_vector_negation() {
    // Test row vector
    let vector = Tensor::new_2d(vec![1.0, 2.0, 3.0], 1, 3).unwrap();
    let value = Value::Tensor(vector);
    let result = elementwise_neg(&value).unwrap();

    if let Value::Tensor(result_matrix) = result {
        assert_eq!(result_matrix.data, vec![-1.0, -2.0, -3.0]);
        assert_eq!(result_matrix.rows(), 1);
        assert_eq!(result_matrix.cols(), 3);
    } else {
        panic!("Expected matrix result");
    }
}

#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test::wasm_bindgen_test)]
#[test]
fn test_zero_negation() {
    // Test that -0 = 0
    let zero = Value::Num(0.0);
    let result = elementwise_neg(&zero).unwrap();
    assert_eq!(result, Value::Num(-0.0));
}

#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test::wasm_bindgen_test)]
#[test]
fn test_unsupported_type() {
    // Test string negation should fail
    let string_val = Value::String("test".to_string());
    let result = elementwise_neg(&string_val);
    assert!(result.is_err());
    assert!(result.unwrap_err().contains("Negation not supported"));
}