#1 Fluffy Labs Meetup

Wrocław, 12 Dec 2024

#1 Fluffy Labs Meetup

Wrocław, 12 Dec 2024

2 Piętro (Klub Proza)

Agenda

  • Od Polkadot do JAM - high level to nitty gritty
    Tomek Drwięga
  • Polka Virtual Machine - co z tym zrobić?
    Mateusz Sikora

Sponsor

Polkadot to JAM

​high level overview to nitty gritty details

Tomek Drwięga
@tomusdrw
Core Developer

Historical view

Ethereum

Polkadot

Gavin Wood

2014 - 2016

2016 - 2017

2017 - 

Ethereum 2016

  • Sequential execution of ALL transactions
  • Slow, custom VM (EVM), lack of dev tooling
  • + additional factors (slow state)
  • = high congestion & fees

Polkadot 2017

  • SHARDED blockchain but SHARED security
  • Shard (aka Parachain) - independent blockchain
  • Shard EXECUTION is VERIFIED on Relay Chain (L0/L1)
  • Checking STF by randomized set of Validators
  • Verification data distributed for auditability (DA)

Polkadot 2017

  • Each SHARD/Rollup is programmable
  • Every SHARD can be a different blockchain
    (HETEROgeneous vs HOMOgeneous)
  • Polkadot-SDK framework compiles
    State Transition Function to WebAssembly
  • Decentralized Sequencers
  • XCMP messaging

more cool stuff

Ethereum 2019-...

  • Ethereum (L1) has heterogeneous Rollups (L2)
  • No hard requirements on what constitutes a rollup:
    • Is it possible to verify STF?
    • Is there enough data?
    • Finality?
    • Fraud proofs? 

Do shards / rollups work?

BUT, shards have their own issues...

  • Sync both SHARD (L2) and the RELAY CHAIN (L1)
    to know the latest state
  • In-SHARD communication = easy
    • Smart contracts speaking to each other
  • Cross-SHARD comms = hard!
    • What's the state of other shard?
    • Asynchronous communication
    • XCM is there in Polkadot, but async
      is not "familiar paradigm" for devs

🤖 Too much NERD STUFF!!!!

Bitcoin

SOFTWARE to transfer FUNDS

from Alice to Bob

Ethereum

PLATFORM to run Smart Contracts (programmable money)

+ rollups Data Availability & settlement*

Polkadot

  • A self-governed DAO
  • Offering Services like:
    Staking, Governance, Treasury, Tokens
  • Smart Contracts Platform (soon on AH)
  • Blockchain hosting platform

Cloud

  • Blockchain Hosting Platform
  • Build with Polkadot-SDK
  • Deploy to Polkadot Cloud
  • AWS for Web3
    • Secure execution
    • Economical Finality
    • Data Availability
    • Object Storage

Hub

  • Running on Polkadot Cloud
    it's first blockchain app!
  • Polkadot Ecosystem
    • Community,
    • Collectives,
    • DOT token,
    • Governance
  • Directed for end-users

Polkadot

Next generation of Polkadot Cloud

Polkadot Hub stays exactly the same
(so do other apps running on the Cloud)

  • Run not only blockchains but arbitrary Web3 Services
    • ​no transactions
  • Blurring the line between:
    • Building and deploying a "traditional" application
      • database + server + long-running execution
    • Building and deploying a blockchain
      • state trie + transactions + per-block execution
  • PolkaVM (PVM)
    state of the art Virtual Machine, much faster than WASM

JAM What?

 

  • More generic definitions of execution primitives
    • In-Core execution
      • controlled by parachain block (programmable)
    • On-Chain execution
      • prev. done at RC (NOW: programmable)
    • Data Availability
      • prev. distributing block data (NOW: programmable)

JAM What?

Details please!

Details please!

  •  JAM supports services (PVM bytecode), with entry points
    • refine - in-core execution
    • accumulate - on-chain execution
    • on_transfer - incoming transfer from a service
  • Service can be invoked via WorkPackage (1 to 4 WorkItems)
  • WorkPackage is distributed in the Data Lake for availability
  • Validators execute in-core portion of the
    WorkPackage and produce WorkResult (
    refinement)
  • WorkResults are aggregated into blocks and accumulated there (on-chain execution).

JAM "hardware" Spec

  • 1023 Validators
    supporting 1.6PB=1.6mil GB (~ 1.5TB per validator) of data in the DA layer (Data Lake)
  • 341 available cores
    3 validators per core; throughput: potentially 682MB/s (2MB/s per core)
  • On-chain Reactor
    synchronous  execution; throughput: 2-6MB/s
    (that's the only thing most blockchains have currently)

JAM Service

  • refine (in-core) 
    • parallel - currently rollup blocks
  • accumulate (on-chain)
    • synchronous - currently relay chain

refine phase (in-core)

  • state-less
    (but can read&write to data availability layer)
  • quite a lot of gas available
    (long
    execution time)
  • parallel execution across cores
    (no info about other cores though)

accumulate phase (on-chain)

  • direct access to the on-chain state
  • less gas available (constrained)
  • fully synchronous access to WorkResults
    (all services; possibly from all cores at once)

What does it all mean?

🔥 Hot take: JAM is a simpler protocol than Polkadot

CoreChains Service

  • Running Polkadot Hub
  • Running all existing shards (parachains)
  • Backward compatibility with Polkadot Cloud

CoreVM Service

  • Compile regular program (Rust, C++) to PVM
  • Execute like blockchain "Virtual Machine" (in-core)
  • Pause and resume between blocks

CorePlay Service

  • Smart Contracts hosting platform
  • Multi-core scalability
  • Execute Solidity and ink!
  • Open and Permissionless

Tomek Drwięga
@tomusdrw
Core Developer

#1 Fluffy Labs Meetup Wrocław

By Tomasz Drwięga

#1 Fluffy Labs Meetup Wrocław

  • 27