Handle the AllowMultiAssetPools=false case in benchmarks (#14590)

* Handle the AllowMultiAssetPools=false case in benchmarks

* ".git/.scripts/commands/bench/bench.sh" pallet dev pallet_asset_conversion

---------

Co-authored-by: command-bot <>
This commit is contained in:
Jegor Sidorenko
2023-07-18 11:38:03 +02:00
committed by GitHub
parent 856727bf52
commit 26d8e65910
2 changed files with 263 additions and 222 deletions
@@ -28,6 +28,7 @@ use frame_support::{
}, },
}; };
use frame_system::RawOrigin as SystemOrigin; use frame_system::RawOrigin as SystemOrigin;
use sp_core::Get;
use sp_runtime::traits::{Bounded, StaticLookup}; use sp_runtime::traits::{Bounded, StaticLookup};
use sp_std::{ops::Div, prelude::*}; use sp_std::{ops::Div, prelude::*};
@@ -168,117 +169,160 @@ benchmarks! {
} }
swap_exact_tokens_for_tokens { swap_exact_tokens_for_tokens {
let asset1 = T::MultiAssetIdConverter::get_native(); let native = T::MultiAssetIdConverter::get_native();
let asset2 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(0)); let asset1 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(1));
let asset3 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(1)); let asset2 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(2));
let asset4 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(2)); let (_, caller, _) = create_asset_and_pool::<T>(&native, &asset1);
let (_, _) = create_asset::<T>(&asset2);
let (_, caller, _) = create_asset_and_pool::<T>(&asset1, &asset2);
let (_, _) = create_asset::<T>(&asset3);
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset2.clone(), asset3.clone())?;
let (_, _) = create_asset::<T>(&asset4);
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset3.clone(), asset4.clone())?;
let path: BoundedVec<_, T::MaxSwapPathLength> =
BoundedVec::try_from(vec![asset1.clone(), asset2.clone(), asset3.clone(), asset4.clone()]).unwrap();
let ed: u128 = T::Currency::minimum_balance().into(); let ed: u128 = T::Currency::minimum_balance().into();
let add_amount1 = 100 * ed;
AssetConversion::<T>::add_liquidity( AssetConversion::<T>::add_liquidity(
SystemOrigin::Signed(caller.clone()).into(), SystemOrigin::Signed(caller.clone()).into(),
native.clone(),
asset1.clone(), asset1.clone(),
asset2.clone(), (100 * ed).into(),
add_amount1.into(),
200.into(), 200.into(),
0.into(), 0.into(),
0.into(), 0.into(),
caller.clone(), caller.clone(),
)?; )?;
AssetConversion::<T>::add_liquidity(
SystemOrigin::Signed(caller.clone()).into(), let path;
asset2.clone(), // if we only allow the native-asset pools, then the worst case scenario would be to swap
asset3.clone(), // asset1-native-asset2
200.into(), if !T::AllowMultiAssetPools::get() {
2000.into(), AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), native.clone(), asset2.clone())?;
0.into(), AssetConversion::<T>::add_liquidity(
0.into(), SystemOrigin::Signed(caller.clone()).into(),
caller.clone(), native.clone(),
)?; asset2.clone(),
AssetConversion::<T>::add_liquidity( (500 * ed).into(),
SystemOrigin::Signed(caller.clone()).into(), 1000.into(),
asset3.clone(), 0.into(),
asset4.clone(), 0.into(),
2000.into(), caller.clone(),
2000.into(), )?;
0.into(), path = vec![asset1.clone(), native.clone(), asset2.clone()];
0.into(), } else {
caller.clone(), let asset3 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(3));
)?; AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset1.clone(), asset2.clone())?;
let asset1_balance = T::Currency::balance(&caller); let (_, _) = create_asset::<T>(&asset3);
}: _(SystemOrigin::Signed(caller.clone()), path.clone(), ed.into(), 1.into(), caller.clone(), false) AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset2.clone(), asset3.clone())?;
AssetConversion::<T>::add_liquidity(
SystemOrigin::Signed(caller.clone()).into(),
asset1.clone(),
asset2.clone(),
200.into(),
2000.into(),
0.into(),
0.into(),
caller.clone(),
)?;
AssetConversion::<T>::add_liquidity(
SystemOrigin::Signed(caller.clone()).into(),
asset2.clone(),
asset3.clone(),
2000.into(),
2000.into(),
0.into(),
0.into(),
caller.clone(),
)?;
path = vec![native.clone(), asset1.clone(), asset2.clone(), asset3.clone()];
}
let path: BoundedVec<_, T::MaxSwapPathLength> = BoundedVec::try_from(path).unwrap();
let native_balance = T::Currency::balance(&caller);
let asset1_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(1), &caller);
}: _(SystemOrigin::Signed(caller.clone()), path, ed.into(), 1.into(), caller.clone(), false)
verify { verify {
let new_asset1_balance = T::Currency::balance(&caller); if !T::AllowMultiAssetPools::get() {
assert_eq!( let new_asset1_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(1), &caller);
new_asset1_balance, assert_eq!(new_asset1_balance, asset1_balance - 100.into());
asset1_balance - ed.into() } else {
); let new_native_balance = T::Currency::balance(&caller);
assert_eq!(new_native_balance, native_balance - ed.into());
}
} }
swap_tokens_for_exact_tokens { swap_tokens_for_exact_tokens {
let asset1 = T::MultiAssetIdConverter::get_native(); let native = T::MultiAssetIdConverter::get_native();
let asset2 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(0)); let asset1 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(1));
let asset3 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(1)); let asset2 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(2));
let asset4 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(2)); let (_, caller, _) = create_asset_and_pool::<T>(&native, &asset1);
let (_, _) = create_asset::<T>(&asset2);
let (_, caller, _) = create_asset_and_pool::<T>(&asset1, &asset2);
let (_, _) = create_asset::<T>(&asset3);
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset2.clone(), asset3.clone())?;
let (_, _) = create_asset::<T>(&asset4);
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset3.clone(), asset4.clone())?;
let path: BoundedVec<_, T::MaxSwapPathLength> =
BoundedVec::try_from(vec![asset1.clone(), asset2.clone(), asset3.clone(), asset4.clone()]).unwrap();
let ed: u128 = T::Currency::minimum_balance().into(); let ed: u128 = T::Currency::minimum_balance().into();
let add_amount1 = 1000 + ed; let add_native = 1000 + ed;
AssetConversion::<T>::add_liquidity( AssetConversion::<T>::add_liquidity(
SystemOrigin::Signed(caller.clone()).into(), SystemOrigin::Signed(caller.clone()).into(),
native.clone(),
asset1.clone(), asset1.clone(),
asset2.clone(), add_native.into(),
add_amount1.into(),
200.into(), 200.into(),
0.into(), 0.into(),
0.into(), 0.into(),
caller.clone(), caller.clone(),
)?; )?;
AssetConversion::<T>::add_liquidity(
SystemOrigin::Signed(caller.clone()).into(), let path;
asset2.clone(), // if we only allow the native-asset pools, then the worst case scenario would be to swap
asset3.clone(), // asset1-native-asset2
200.into(), if !T::AllowMultiAssetPools::get() {
2000.into(), AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), native.clone(), asset2.clone())?;
0.into(), AssetConversion::<T>::add_liquidity(
0.into(), SystemOrigin::Signed(caller.clone()).into(),
caller.clone(), native.clone(),
)?; asset2.clone(),
AssetConversion::<T>::add_liquidity( (500 + ed).into(),
SystemOrigin::Signed(caller.clone()).into(), 1000.into(),
asset3.clone(), 0.into(),
asset4.clone(), 0.into(),
2000.into(), caller.clone(),
2000.into(), )?;
0.into(), path = vec![asset1.clone(), native.clone(), asset2.clone()];
0.into(), } else {
caller.clone(), AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset1.clone(), asset2.clone())?;
)?; let asset3 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(3));
let asset4_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(2), &caller); let (_, _) = create_asset::<T>(&asset3);
}: _(SystemOrigin::Signed(caller.clone()), path.clone(), 100.into(), add_amount1.into(), caller.clone(), false) AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset2.clone(), asset3.clone())?;
AssetConversion::<T>::add_liquidity(
SystemOrigin::Signed(caller.clone()).into(),
asset1.clone(),
asset2.clone(),
200.into(),
2000.into(),
0.into(),
0.into(),
caller.clone(),
)?;
AssetConversion::<T>::add_liquidity(
SystemOrigin::Signed(caller.clone()).into(),
asset2.clone(),
asset3.clone(),
2000.into(),
2000.into(),
0.into(),
0.into(),
caller.clone(),
)?;
path = vec![native.clone(), asset1.clone(), asset2.clone(), asset3.clone()];
}
let path: BoundedVec<_, T::MaxSwapPathLength> = BoundedVec::try_from(path).unwrap();
let asset2_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(2), &caller);
let asset3_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(3), &caller);
}: _(SystemOrigin::Signed(caller.clone()), path.clone(), 100.into(), add_native.into(), caller.clone(), false)
verify { verify {
let new_asset4_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(2), &caller); if !T::AllowMultiAssetPools::get() {
assert_eq!( let new_asset2_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(2), &caller);
new_asset4_balance, assert_eq!(new_asset2_balance, asset2_balance + 100.into());
asset4_balance + 100.into() } else {
); let new_asset3_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(3), &caller);
assert_eq!(new_asset3_balance, asset3_balance + 100.into());
}
} }
impl_benchmark_test_suite!(AssetConversion, crate::mock::new_test_ext(), crate::mock::Test); impl_benchmark_test_suite!(AssetConversion, crate::mock::new_test_ext(), crate::mock::Test);
+133 -136
View File
@@ -18,28 +18,25 @@
//! Autogenerated weights for pallet_asset_conversion //! Autogenerated weights for pallet_asset_conversion
//! //!
//! THIS FILE WAS AUTO-GENERATED USING THE SUBSTRATE BENCHMARK CLI VERSION 4.0.0-dev //! THIS FILE WAS AUTO-GENERATED USING THE SUBSTRATE BENCHMARK CLI VERSION 4.0.0-dev
//! DATE: 2023-06-16, STEPS: `50`, REPEAT: `20`, LOW RANGE: `[]`, HIGH RANGE: `[]` //! DATE: 2023-07-17, STEPS: `50`, REPEAT: `20`, LOW RANGE: `[]`, HIGH RANGE: `[]`
//! WORST CASE MAP SIZE: `1000000` //! WORST CASE MAP SIZE: `1000000`
//! HOSTNAME: `runner-e8ezs4ez-project-145-concurrent-0`, CPU: `Intel(R) Xeon(R) CPU @ 2.60GHz` //! HOSTNAME: `runner-gghbxkbs-project-145-concurrent-0`, CPU: `Intel(R) Xeon(R) CPU @ 2.60GHz`
//! EXECUTION: Some(Wasm), WASM-EXECUTION: Compiled, CHAIN: Some("dev"), DB CACHE: 1024 //! EXECUTION: ``, WASM-EXECUTION: `Compiled`, CHAIN: `Some("dev")`, DB CACHE: `1024`
// Executed Command: // Executed Command:
// ./target/production/substrate // target/production/substrate
// benchmark // benchmark
// pallet // pallet
// --chain=dev
// --steps=50 // --steps=50
// --repeat=20 // --repeat=20
// --pallet=pallet_asset_conversion
// --no-storage-info
// --no-median-slopes
// --no-min-squares
// --extrinsic=* // --extrinsic=*
// --execution=wasm
// --wasm-execution=compiled // --wasm-execution=compiled
// --heap-pages=4096 // --heap-pages=4096
// --output=./frame/asset-conversion/src/weights.rs // --json-file=/builds/parity/mirrors/substrate/.git/.artifacts/bench.json
// --pallet=pallet_asset_conversion
// --chain=dev
// --header=./HEADER-APACHE2 // --header=./HEADER-APACHE2
// --output=./frame/asset-conversion/src/weights.rs
// --template=./.maintain/frame-weight-template.hbs // --template=./.maintain/frame-weight-template.hbs
#![cfg_attr(rustfmt, rustfmt_skip)] #![cfg_attr(rustfmt, rustfmt_skip)]
@@ -62,197 +59,197 @@ pub trait WeightInfo {
/// Weights for pallet_asset_conversion using the Substrate node and recommended hardware. /// Weights for pallet_asset_conversion using the Substrate node and recommended hardware.
pub struct SubstrateWeight<T>(PhantomData<T>); pub struct SubstrateWeight<T>(PhantomData<T>);
impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> { impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
/// Storage: AssetConversion Pools (r:1 w:1) /// Storage: `AssetConversion::Pools` (r:1 w:1)
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen) /// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
/// Storage: System Account (r:2 w:2) /// Storage: `System::Account` (r:2 w:2)
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen) /// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
/// Storage: Assets Account (r:1 w:1) /// Storage: `Assets::Account` (r:1 w:1)
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
/// Storage: Assets Asset (r:1 w:1) /// Storage: `Assets::Asset` (r:1 w:1)
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: AssetConversion NextPoolAssetId (r:1 w:1) /// Storage: `AssetConversion::NextPoolAssetId` (r:1 w:1)
/// Proof: AssetConversion NextPoolAssetId (max_values: Some(1), max_size: Some(4), added: 499, mode: MaxEncodedLen) /// Proof: `AssetConversion::NextPoolAssetId` (`max_values`: Some(1), `max_size`: Some(4), added: 499, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Asset (r:1 w:1) /// Storage: `PoolAssets::Asset` (r:1 w:1)
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Account (r:1 w:1) /// Storage: `PoolAssets::Account` (r:1 w:1)
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
fn create_pool() -> Weight { fn create_pool() -> Weight {
// Proof Size summary in bytes: // Proof Size summary in bytes:
// Measured: `729` // Measured: `729`
// Estimated: `6196` // Estimated: `6196`
// Minimum execution time: 129_741_000 picoseconds. // Minimum execution time: 131_549_000 picoseconds.
Weight::from_parts(132_516_000, 6196) Weight::from_parts(134_287_000, 6196)
.saturating_add(T::DbWeight::get().reads(8_u64)) .saturating_add(T::DbWeight::get().reads(8_u64))
.saturating_add(T::DbWeight::get().writes(8_u64)) .saturating_add(T::DbWeight::get().writes(8_u64))
} }
/// Storage: AssetConversion Pools (r:1 w:0) /// Storage: `AssetConversion::Pools` (r:1 w:0)
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen) /// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
/// Storage: System Account (r:1 w:1) /// Storage: `System::Account` (r:1 w:1)
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen) /// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
/// Storage: Assets Asset (r:1 w:1) /// Storage: `Assets::Asset` (r:1 w:1)
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: Assets Account (r:2 w:2) /// Storage: `Assets::Account` (r:2 w:2)
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Asset (r:1 w:1) /// Storage: `PoolAssets::Asset` (r:1 w:1)
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Account (r:2 w:2) /// Storage: `PoolAssets::Account` (r:2 w:2)
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
fn add_liquidity() -> Weight { fn add_liquidity() -> Weight {
// Proof Size summary in bytes: // Proof Size summary in bytes:
// Measured: `1382` // Measured: `1382`
// Estimated: `6208` // Estimated: `6208`
// Minimum execution time: 154_821_000 picoseconds. // Minimum execution time: 156_395_000 picoseconds.
Weight::from_parts(157_855_000, 6208) Weight::from_parts(157_952_000, 6208)
.saturating_add(T::DbWeight::get().reads(8_u64)) .saturating_add(T::DbWeight::get().reads(8_u64))
.saturating_add(T::DbWeight::get().writes(7_u64)) .saturating_add(T::DbWeight::get().writes(7_u64))
} }
/// Storage: AssetConversion Pools (r:1 w:0) /// Storage: `AssetConversion::Pools` (r:1 w:0)
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen) /// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
/// Storage: System Account (r:1 w:1) /// Storage: `System::Account` (r:1 w:1)
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen) /// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
/// Storage: Assets Asset (r:1 w:1) /// Storage: `Assets::Asset` (r:1 w:1)
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: Assets Account (r:2 w:2) /// Storage: `Assets::Account` (r:2 w:2)
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Asset (r:1 w:1) /// Storage: `PoolAssets::Asset` (r:1 w:1)
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Account (r:1 w:1) /// Storage: `PoolAssets::Account` (r:1 w:1)
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
fn remove_liquidity() -> Weight { fn remove_liquidity() -> Weight {
// Proof Size summary in bytes: // Proof Size summary in bytes:
// Measured: `1371` // Measured: `1371`
// Estimated: `6208` // Estimated: `6208`
// Minimum execution time: 139_490_000 picoseconds. // Minimum execution time: 140_295_000 picoseconds.
Weight::from_parts(143_626_000, 6208) Weight::from_parts(143_452_000, 6208)
.saturating_add(T::DbWeight::get().reads(7_u64)) .saturating_add(T::DbWeight::get().reads(7_u64))
.saturating_add(T::DbWeight::get().writes(6_u64)) .saturating_add(T::DbWeight::get().writes(6_u64))
} }
/// Storage: System Account (r:1 w:1) /// Storage: `System::Account` (r:1 w:1)
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen) /// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
/// Storage: Assets Asset (r:3 w:3) /// Storage: `Assets::Asset` (r:3 w:3)
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: Assets Account (r:6 w:6) /// Storage: `Assets::Account` (r:6 w:6)
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
fn swap_exact_tokens_for_tokens() -> Weight { fn swap_exact_tokens_for_tokens() -> Weight {
// Proof Size summary in bytes: // Proof Size summary in bytes:
// Measured: `1732` // Measured: `1738`
// Estimated: `16644` // Estimated: `16644`
// Minimum execution time: 212_868_000 picoseconds. // Minimum execution time: 214_657_000 picoseconds.
Weight::from_parts(221_638_000, 16644) Weight::from_parts(217_657_000, 16644)
.saturating_add(T::DbWeight::get().reads(10_u64)) .saturating_add(T::DbWeight::get().reads(10_u64))
.saturating_add(T::DbWeight::get().writes(10_u64)) .saturating_add(T::DbWeight::get().writes(10_u64))
} }
/// Storage: Assets Asset (r:3 w:3) /// Storage: `Assets::Asset` (r:3 w:3)
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: Assets Account (r:6 w:6) /// Storage: `Assets::Account` (r:6 w:6)
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
/// Storage: System Account (r:1 w:1) /// Storage: `System::Account` (r:1 w:1)
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen) /// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
fn swap_tokens_for_exact_tokens() -> Weight { fn swap_tokens_for_exact_tokens() -> Weight {
// Proof Size summary in bytes: // Proof Size summary in bytes:
// Measured: `1732` // Measured: `1738`
// Estimated: `16644` // Estimated: `16644`
// Minimum execution time: 211_746_000 picoseconds. // Minimum execution time: 215_319_000 picoseconds.
Weight::from_parts(217_322_000, 16644) Weight::from_parts(218_299_000, 16644)
.saturating_add(T::DbWeight::get().reads(10_u64)) .saturating_add(T::DbWeight::get().reads(10_u64))
.saturating_add(T::DbWeight::get().writes(10_u64)) .saturating_add(T::DbWeight::get().writes(10_u64))
} }
} }
// For backwards compatibility and tests // For backwards compatibility and tests.
impl WeightInfo for () { impl WeightInfo for () {
/// Storage: AssetConversion Pools (r:1 w:1) /// Storage: `AssetConversion::Pools` (r:1 w:1)
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen) /// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
/// Storage: System Account (r:2 w:2) /// Storage: `System::Account` (r:2 w:2)
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen) /// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
/// Storage: Assets Account (r:1 w:1) /// Storage: `Assets::Account` (r:1 w:1)
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
/// Storage: Assets Asset (r:1 w:1) /// Storage: `Assets::Asset` (r:1 w:1)
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: AssetConversion NextPoolAssetId (r:1 w:1) /// Storage: `AssetConversion::NextPoolAssetId` (r:1 w:1)
/// Proof: AssetConversion NextPoolAssetId (max_values: Some(1), max_size: Some(4), added: 499, mode: MaxEncodedLen) /// Proof: `AssetConversion::NextPoolAssetId` (`max_values`: Some(1), `max_size`: Some(4), added: 499, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Asset (r:1 w:1) /// Storage: `PoolAssets::Asset` (r:1 w:1)
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Account (r:1 w:1) /// Storage: `PoolAssets::Account` (r:1 w:1)
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
fn create_pool() -> Weight { fn create_pool() -> Weight {
// Proof Size summary in bytes: // Proof Size summary in bytes:
// Measured: `729` // Measured: `729`
// Estimated: `6196` // Estimated: `6196`
// Minimum execution time: 129_741_000 picoseconds. // Minimum execution time: 131_549_000 picoseconds.
Weight::from_parts(132_516_000, 6196) Weight::from_parts(134_287_000, 6196)
.saturating_add(RocksDbWeight::get().reads(8_u64)) .saturating_add(RocksDbWeight::get().reads(8_u64))
.saturating_add(RocksDbWeight::get().writes(8_u64)) .saturating_add(RocksDbWeight::get().writes(8_u64))
} }
/// Storage: AssetConversion Pools (r:1 w:0) /// Storage: `AssetConversion::Pools` (r:1 w:0)
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen) /// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
/// Storage: System Account (r:1 w:1) /// Storage: `System::Account` (r:1 w:1)
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen) /// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
/// Storage: Assets Asset (r:1 w:1) /// Storage: `Assets::Asset` (r:1 w:1)
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: Assets Account (r:2 w:2) /// Storage: `Assets::Account` (r:2 w:2)
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Asset (r:1 w:1) /// Storage: `PoolAssets::Asset` (r:1 w:1)
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Account (r:2 w:2) /// Storage: `PoolAssets::Account` (r:2 w:2)
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
fn add_liquidity() -> Weight { fn add_liquidity() -> Weight {
// Proof Size summary in bytes: // Proof Size summary in bytes:
// Measured: `1382` // Measured: `1382`
// Estimated: `6208` // Estimated: `6208`
// Minimum execution time: 154_821_000 picoseconds. // Minimum execution time: 156_395_000 picoseconds.
Weight::from_parts(157_855_000, 6208) Weight::from_parts(157_952_000, 6208)
.saturating_add(RocksDbWeight::get().reads(8_u64)) .saturating_add(RocksDbWeight::get().reads(8_u64))
.saturating_add(RocksDbWeight::get().writes(7_u64)) .saturating_add(RocksDbWeight::get().writes(7_u64))
} }
/// Storage: AssetConversion Pools (r:1 w:0) /// Storage: `AssetConversion::Pools` (r:1 w:0)
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen) /// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
/// Storage: System Account (r:1 w:1) /// Storage: `System::Account` (r:1 w:1)
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen) /// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
/// Storage: Assets Asset (r:1 w:1) /// Storage: `Assets::Asset` (r:1 w:1)
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: Assets Account (r:2 w:2) /// Storage: `Assets::Account` (r:2 w:2)
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Asset (r:1 w:1) /// Storage: `PoolAssets::Asset` (r:1 w:1)
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: PoolAssets Account (r:1 w:1) /// Storage: `PoolAssets::Account` (r:1 w:1)
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
fn remove_liquidity() -> Weight { fn remove_liquidity() -> Weight {
// Proof Size summary in bytes: // Proof Size summary in bytes:
// Measured: `1371` // Measured: `1371`
// Estimated: `6208` // Estimated: `6208`
// Minimum execution time: 139_490_000 picoseconds. // Minimum execution time: 140_295_000 picoseconds.
Weight::from_parts(143_626_000, 6208) Weight::from_parts(143_452_000, 6208)
.saturating_add(RocksDbWeight::get().reads(7_u64)) .saturating_add(RocksDbWeight::get().reads(7_u64))
.saturating_add(RocksDbWeight::get().writes(6_u64)) .saturating_add(RocksDbWeight::get().writes(6_u64))
} }
/// Storage: System Account (r:1 w:1) /// Storage: `System::Account` (r:1 w:1)
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen) /// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
/// Storage: Assets Asset (r:3 w:3) /// Storage: `Assets::Asset` (r:3 w:3)
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: Assets Account (r:6 w:6) /// Storage: `Assets::Account` (r:6 w:6)
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
fn swap_exact_tokens_for_tokens() -> Weight { fn swap_exact_tokens_for_tokens() -> Weight {
// Proof Size summary in bytes: // Proof Size summary in bytes:
// Measured: `1732` // Measured: `1738`
// Estimated: `16644` // Estimated: `16644`
// Minimum execution time: 212_868_000 picoseconds. // Minimum execution time: 214_657_000 picoseconds.
Weight::from_parts(221_638_000, 16644) Weight::from_parts(217_657_000, 16644)
.saturating_add(RocksDbWeight::get().reads(10_u64)) .saturating_add(RocksDbWeight::get().reads(10_u64))
.saturating_add(RocksDbWeight::get().writes(10_u64)) .saturating_add(RocksDbWeight::get().writes(10_u64))
} }
/// Storage: Assets Asset (r:3 w:3) /// Storage: `Assets::Asset` (r:3 w:3)
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen) /// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
/// Storage: Assets Account (r:6 w:6) /// Storage: `Assets::Account` (r:6 w:6)
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen) /// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
/// Storage: System Account (r:1 w:1) /// Storage: `System::Account` (r:1 w:1)
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen) /// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
fn swap_tokens_for_exact_tokens() -> Weight { fn swap_tokens_for_exact_tokens() -> Weight {
// Proof Size summary in bytes: // Proof Size summary in bytes:
// Measured: `1732` // Measured: `1738`
// Estimated: `16644` // Estimated: `16644`
// Minimum execution time: 211_746_000 picoseconds. // Minimum execution time: 215_319_000 picoseconds.
Weight::from_parts(217_322_000, 16644) Weight::from_parts(218_299_000, 16644)
.saturating_add(RocksDbWeight::get().reads(10_u64)) .saturating_add(RocksDbWeight::get().reads(10_u64))
.saturating_add(RocksDbWeight::get().writes(10_u64)) .saturating_add(RocksDbWeight::get().writes(10_u64))
} }