Skip to content

Commit

Permalink
shortcircuit when inlined (i.e. when root is leaf)
Browse files Browse the repository at this point in the history
  • Loading branch information
igor-aptos committed Dec 12, 2024
1 parent 442a55d commit 8f766f2
Show file tree
Hide file tree
Showing 14 changed files with 807 additions and 621 deletions.
16 changes: 8 additions & 8 deletions aptos-move/e2e-benchmark/data/calibration_values.tsv
Original file line number Diff line number Diff line change
Expand Up @@ -33,11 +33,11 @@ VectorRangeMove { vec_len: 3000, element_len: 1, index: 1000, move_len: 500, rep
VectorTrimAppend { vec_len: 100, element_len: 100, index: 0, repeats: 0 } 6 0.925 1.001 277.0
VectorTrimAppend { vec_len: 100, element_len: 100, index: 10, repeats: 1000 } 6 0.925 1.001 12146.6
VectorRangeMove { vec_len: 100, element_len: 100, index: 50, move_len: 10, repeats: 1000 } 6 0.925 1.001 7098
MapInsertRemove { len: 10, repeats: 0, use_simple_map: false } 6 0.925 1.001 378
MapInsertRemove { len: 10, repeats: 100, use_simple_map: false } 6 0.925 1.001 8184
MapInsertRemove { len: 10, repeats: 100, use_simple_map: true } 6 0.925 1.001 6419
MapInsertRemove { len: 100, repeats: 0, use_simple_map: false } 6 0.925 1.001 5094
MapInsertRemove { len: 100, repeats: 100, use_simple_map: false } 6 0.925 1.001 15838
MapInsertRemove { len: 100, repeats: 100, use_simple_map: true } 6 0.925 1.001 30962
MapInsertRemove { len: 1000, repeats: 0, use_simple_map: false } 6 0.925 1.001 66878
MapInsertRemove { len: 1000, repeats: 100, use_simple_map: false } 6 0.925 1.001 79826
MapInsertRemove { len: 10, repeats: 0, map_type: OrderedMap } 6 0.925 1.001 378
MapInsertRemove { len: 10, repeats: 100, map_type: OrderedMap } 6 0.925 1.001 8184
MapInsertRemove { len: 10, repeats: 100, map_type: SimpleMap } 6 0.925 1.001 6419
MapInsertRemove { len: 100, repeats: 0, map_type: OrderedMap } 6 0.925 1.001 5094
MapInsertRemove { len: 100, repeats: 100, map_type: OrderedMap } 6 0.925 1.001 15838
MapInsertRemove { len: 100, repeats: 100, map_type: SimpleMap } 6 0.925 1.001 30962
MapInsertRemove { len: 1000, repeats: 0, map_type: OrderedMap } 6 0.925 1.001 66878
MapInsertRemove { len: 1000, repeats: 100, map_type: OrderedMap } 6 0.925 1.001 79826
18 changes: 9 additions & 9 deletions aptos-move/e2e-benchmark/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ use aptos_language_e2e_tests::{
};
use aptos_transaction_generator_lib::{
publishing::{
module_simple::{AutomaticArgs, LoopType, MultiSigConfig},
module_simple::{AutomaticArgs, LoopType, MapType, MultiSigConfig},
publish_util::{Package, PackageHandler},
},
EntryPoints,
Expand Down Expand Up @@ -239,42 +239,42 @@ fn main() {
EntryPoints::MapInsertRemove {
len: 10,
repeats: 0,
use_simple_map: false,
map_type: MapType::OrderedMap,
},
EntryPoints::MapInsertRemove {
len: 10,
repeats: 100,
use_simple_map: false,
map_type: MapType::OrderedMap,
},
EntryPoints::MapInsertRemove {
len: 10,
repeats: 100,
use_simple_map: true,
map_type: MapType::SimpleMap,
},
EntryPoints::MapInsertRemove {
len: 100,
repeats: 0,
use_simple_map: false,
map_type: MapType::OrderedMap,
},
EntryPoints::MapInsertRemove {
len: 100,
repeats: 100,
use_simple_map: false,
map_type: MapType::OrderedMap,
},
EntryPoints::MapInsertRemove {
len: 100,
repeats: 100,
use_simple_map: true,
map_type: MapType::SimpleMap,
},
EntryPoints::MapInsertRemove {
len: 1000,
repeats: 0,
use_simple_map: false,
map_type: MapType::OrderedMap,
},
EntryPoints::MapInsertRemove {
len: 1000,
repeats: 100,
use_simple_map: false,
map_type: MapType::OrderedMap,
},
];

Expand Down
587 changes: 371 additions & 216 deletions aptos-move/framework/aptos-stdlib/doc/big_ordered_map.md

Large diffs are not rendered by default.

147 changes: 42 additions & 105 deletions aptos-move/framework/aptos-stdlib/doc/storage_slots_allocator.md

Large diffs are not rendered by default.

20 changes: 10 additions & 10 deletions aptos-move/framework/aptos-stdlib/doc/table.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ struct itself, while the operations are implemented as native functions. No trav
- [Function `upsert`](#0x1_table_upsert)
- [Function `remove`](#0x1_table_remove)
- [Function `contains`](#0x1_table_contains)
- [Function `destroy`](#0x1_table_destroy)
- [Function `destroy_known_empty_unsafe`](#0x1_table_destroy_known_empty_unsafe)
- [Function `new_table_handle`](#0x1_table_new_table_handle)
- [Function `add_box`](#0x1_table_add_box)
- [Function `borrow_box`](#0x1_table_borrow_box)
Expand All @@ -41,7 +41,7 @@ struct itself, while the operations are implemented as native functions. No trav
- [Function `upsert`](#@Specification_0_upsert)
- [Function `remove`](#@Specification_0_remove)
- [Function `contains`](#@Specification_0_contains)
- [Function `destroy`](#@Specification_0_destroy)
- [Function `destroy_known_empty_unsafe`](#@Specification_0_destroy_known_empty_unsafe)


<pre><code></code></pre>
Expand Down Expand Up @@ -352,15 +352,15 @@ Returns true iff <code>self</code> contains an entry for <code>key</code>.

</details>

<a id="0x1_table_destroy"></a>
<a id="0x1_table_destroy_known_empty_unsafe"></a>

## Function `destroy`
## Function `destroy_known_empty_unsafe`

Table cannot know if it is empty or not, so this method is not public,
and can be used only in modules that know by themselves that table is empty.


<pre><code><b>public</b>(<b>friend</b>) <b>fun</b> <a href="table.md#0x1_table_destroy">destroy</a>&lt;K: <b>copy</b>, drop, V&gt;(self: <a href="table.md#0x1_table_Table">table::Table</a>&lt;K, V&gt;)
<pre><code><b>public</b>(<b>friend</b>) <b>fun</b> <a href="table.md#0x1_table_destroy_known_empty_unsafe">destroy_known_empty_unsafe</a>&lt;K: <b>copy</b>, drop, V&gt;(self: <a href="table.md#0x1_table_Table">table::Table</a>&lt;K, V&gt;)
</code></pre>


Expand All @@ -369,7 +369,7 @@ and can be used only in modules that know by themselves that table is empty.
<summary>Implementation</summary>


<pre><code><b>public</b>(<b>friend</b>) <b>fun</b> <a href="table.md#0x1_table_destroy">destroy</a>&lt;K: <b>copy</b> + drop, V&gt;(self: <a href="table.md#0x1_table_Table">Table</a>&lt;K, V&gt;) {
<pre><code><b>public</b>(<b>friend</b>) <b>fun</b> <a href="table.md#0x1_table_destroy_known_empty_unsafe">destroy_known_empty_unsafe</a>&lt;K: <b>copy</b> + drop, V&gt;(self: <a href="table.md#0x1_table_Table">Table</a>&lt;K, V&gt;) {
<a href="table.md#0x1_table_destroy_empty_box">destroy_empty_box</a>&lt;K, V, <a href="table.md#0x1_table_Box">Box</a>&lt;V&gt;&gt;(&self);
<a href="table.md#0x1_table_drop_unchecked_box">drop_unchecked_box</a>&lt;K, V, <a href="table.md#0x1_table_Box">Box</a>&lt;V&gt;&gt;(self)
}
Expand Down Expand Up @@ -583,7 +583,7 @@ and can be used only in modules that know by themselves that table is empty.

<pre><code><b>pragma</b> intrinsic = map,
map_new = new,
map_destroy_empty = destroy,
map_destroy_empty = destroy_known_empty_unsafe,
map_has_key = contains,
map_add_no_override = add,
map_add_override_if_exists = upsert,
Expand Down Expand Up @@ -763,12 +763,12 @@ and can be used only in modules that know by themselves that table is empty.



<a id="@Specification_0_destroy"></a>
<a id="@Specification_0_destroy_known_empty_unsafe"></a>

### Function `destroy`
### Function `destroy_known_empty_unsafe`


<pre><code><b>public</b>(<b>friend</b>) <b>fun</b> <a href="table.md#0x1_table_destroy">destroy</a>&lt;K: <b>copy</b>, drop, V&gt;(self: <a href="table.md#0x1_table_Table">table::Table</a>&lt;K, V&gt;)
<pre><code><b>public</b>(<b>friend</b>) <b>fun</b> <a href="table.md#0x1_table_destroy_known_empty_unsafe">destroy_known_empty_unsafe</a>&lt;K: <b>copy</b>, drop, V&gt;(self: <a href="table.md#0x1_table_Table">table::Table</a>&lt;K, V&gt;)
</code></pre>


Expand Down
2 changes: 1 addition & 1 deletion aptos-move/framework/aptos-stdlib/doc/table_with_length.md
Original file line number Diff line number Diff line change
Expand Up @@ -153,7 +153,7 @@ Destroy a table. The table must be empty to succeed.
<pre><code><b>public</b> <b>fun</b> <a href="table_with_length.md#0x1_table_with_length_destroy_empty">destroy_empty</a>&lt;K: <b>copy</b> + drop, V&gt;(self: <a href="table_with_length.md#0x1_table_with_length_TableWithLength">TableWithLength</a>&lt;K, V&gt;) {
<b>assert</b>!(self.length == 0, <a href="../../move-stdlib/doc/error.md#0x1_error_invalid_state">error::invalid_state</a>(<a href="table_with_length.md#0x1_table_with_length_ENOT_EMPTY">ENOT_EMPTY</a>));
<b>let</b> <a href="table_with_length.md#0x1_table_with_length_TableWithLength">TableWithLength</a> { inner, length: _ } = self;
<a href="table.md#0x1_table_destroy">table::destroy</a>(inner)
<a href="table.md#0x1_table_destroy_known_empty_unsafe">table::destroy_known_empty_unsafe</a>(inner)
}
</code></pre>

Expand Down
Loading

0 comments on commit 8f766f2

Please sign in to comment.