160 lines
4 KiB
Rust
160 lines
4 KiB
Rust
//@ needs-enzyme
|
|
|
|
#![feature(autodiff)]
|
|
//@ pretty-mode:expanded
|
|
//@ pretty-compare-only
|
|
//@ pp-exact:autodiff_illegal.pp
|
|
|
|
// Test that invalid ad macros give nice errors and don't ICE.
|
|
|
|
use std::autodiff::autodiff;
|
|
|
|
// We can't use Duplicated on scalars
|
|
#[autodiff(df1, Reverse, Duplicated)]
|
|
pub fn f1(x: f64) {
|
|
//~^ ERROR Duplicated can not be used for this type
|
|
unimplemented!()
|
|
}
|
|
|
|
// Too many activities
|
|
#[autodiff(df3, Reverse, Duplicated, Const)]
|
|
pub fn f3(x: f64) {
|
|
//~^^ ERROR expected 1 activities, but found 2
|
|
unimplemented!()
|
|
}
|
|
|
|
// To few activities
|
|
#[autodiff(df4, Reverse)]
|
|
pub fn f4(x: f64) {
|
|
//~^^ ERROR expected 1 activities, but found 0
|
|
unimplemented!()
|
|
}
|
|
|
|
// We can't use Dual in Reverse mode
|
|
#[autodiff(df5, Reverse, Dual)]
|
|
pub fn f5(x: f64) {
|
|
//~^^ ERROR Dual can not be used in Reverse Mode
|
|
unimplemented!()
|
|
}
|
|
|
|
// We can't use Duplicated in Forward mode
|
|
#[autodiff(df6, Forward, Duplicated)]
|
|
pub fn f6(x: f64) {
|
|
//~^^ ERROR Duplicated can not be used in Forward Mode
|
|
//~^^ ERROR Duplicated can not be used for this type
|
|
unimplemented!()
|
|
}
|
|
|
|
fn dummy() {
|
|
|
|
#[autodiff(df7, Forward, Dual)]
|
|
let mut x = 5;
|
|
//~^ ERROR autodiff must be applied to function
|
|
|
|
#[autodiff(df7, Forward, Dual)]
|
|
x = x + 3;
|
|
//~^^ ERROR attributes on expressions are experimental [E0658]
|
|
//~^^ ERROR autodiff must be applied to function
|
|
|
|
#[autodiff(df7, Forward, Dual)]
|
|
let add_one_v2 = |x: u32| -> u32 { x + 1 };
|
|
//~^ ERROR autodiff must be applied to function
|
|
}
|
|
|
|
// Malformed, where args?
|
|
#[autodiff]
|
|
pub fn f7(x: f64) {
|
|
//~^ ERROR autodiff must be applied to function
|
|
unimplemented!()
|
|
}
|
|
|
|
// Malformed, where args?
|
|
#[autodiff()]
|
|
pub fn f8(x: f64) {
|
|
//~^ ERROR autodiff requires at least a name and mode
|
|
unimplemented!()
|
|
}
|
|
|
|
// Invalid attribute syntax
|
|
#[autodiff = ""]
|
|
pub fn f9(x: f64) {
|
|
//~^ ERROR autodiff must be applied to function
|
|
unimplemented!()
|
|
}
|
|
|
|
fn fn_exists() {}
|
|
|
|
// We colide with an already existing function
|
|
#[autodiff(fn_exists, Reverse, Active)]
|
|
pub fn f10(x: f64) {
|
|
//~^^ ERROR the name `fn_exists` is defined multiple times [E0428]
|
|
unimplemented!()
|
|
}
|
|
|
|
// Malformed, missing a mode
|
|
#[autodiff(df11)]
|
|
pub fn f11() {
|
|
//~^ ERROR autodiff requires at least a name and mode
|
|
unimplemented!()
|
|
}
|
|
|
|
// Invalid Mode
|
|
#[autodiff(df12, Debug)]
|
|
pub fn f12() {
|
|
//~^^ ERROR unknown Mode: `Debug`. Use `Forward` or `Reverse`
|
|
unimplemented!()
|
|
}
|
|
|
|
// Invalid, please pick one Mode
|
|
// or use two autodiff macros.
|
|
#[autodiff(df13, Forward, Reverse)]
|
|
pub fn f13() {
|
|
//~^^ ERROR did not recognize Activity: `Reverse`
|
|
unimplemented!()
|
|
}
|
|
|
|
struct Foo {}
|
|
|
|
// We can't handle Active structs, because that would mean (in the general case), that we would
|
|
// need to allocate and initialize arbitrary user types. We have Duplicated/Dual input args for
|
|
// that. FIXME: Give a nicer error and suggest to the user to have a `&mut Foo` input instead.
|
|
#[autodiff(df14, Reverse, Active, Active)]
|
|
fn f14(x: f32) -> Foo {
|
|
unimplemented!()
|
|
}
|
|
|
|
type MyFloat = f32;
|
|
|
|
// We would like to support type alias to f32/f64 in argument type in the future,
|
|
// but that requires us to implement our checks at a later stage
|
|
// like THIR which has type information available.
|
|
#[autodiff(df15, Reverse, Active, Active)]
|
|
fn f15(x: MyFloat) -> f32 {
|
|
//~^^ ERROR failed to resolve: use of undeclared type `MyFloat` [E0433]
|
|
unimplemented!()
|
|
}
|
|
|
|
// We would like to support type alias to f32/f64 in return type in the future
|
|
#[autodiff(df16, Reverse, Active, Active)]
|
|
fn f16(x: f32) -> MyFloat {
|
|
unimplemented!()
|
|
}
|
|
|
|
#[repr(transparent)]
|
|
struct F64Trans { inner: f64 }
|
|
|
|
// We would like to support `#[repr(transparent)]` f32/f64 wrapper in return type in the future
|
|
#[autodiff(df17, Reverse, Active, Active)]
|
|
fn f17(x: f64) -> F64Trans {
|
|
unimplemented!()
|
|
}
|
|
|
|
// We would like to support `#[repr(transparent)]` f32/f64 wrapper in argument type in the future
|
|
#[autodiff(df18, Reverse, Active, Active)]
|
|
fn f18(x: F64Trans) -> f64 {
|
|
//~^^ ERROR failed to resolve: use of undeclared type `F64Trans` [E0433]
|
|
unimplemented!()
|
|
}
|
|
|
|
|
|
fn main() {}
|