forked from StudioInfinity/dyna3

The new layout deviates from what the Rust book suggests https://doc.rust-lang.org/book/ch11-03-test-organization.html#submodules-in-integration-tests and uses the frowned-upon `#[path]` attribute, https://doc.rust-lang.org/style-guide/advice.html#modules but we've decided that having a descriptive module filename instead of `mod.rs` is worth the cost.
29 lines
No EOL
863 B
Rust
29 lines
No EOL
863 B
Rust
#[path = "common/print.rs"]
|
|
mod print;
|
|
|
|
use dyna3::engine::{realize_gram, sphere, ConstraintProblem, Realization};
|
|
|
|
fn main() {
|
|
let mut problem = ConstraintProblem::from_guess({
|
|
let a: f64 = 0.75_f64.sqrt();
|
|
&[
|
|
sphere(1.0, 0.0, 0.0, 1.0),
|
|
sphere(-0.5, a, 0.0, 1.0),
|
|
sphere(-0.5, -a, 0.0, 1.0)
|
|
]
|
|
});
|
|
for j in 0..3 {
|
|
for k in j..3 {
|
|
problem.gram.push_sym(j, k, if j == k { 1.0 } else { -1.0 });
|
|
}
|
|
}
|
|
let realization_result = realize_gram(
|
|
&problem, 1.0e-12, 0.5, 0.9, 1.1, 200, 110
|
|
);
|
|
print::title("Three spheres");
|
|
print::realization_diagnostics(&realization_result);
|
|
if let Ok(Realization{ config, .. }) = realization_result.result {
|
|
print::gram_matrix(&config);
|
|
}
|
|
print::loss_history(&realization_result.history);
|
|
} |