区块链中的gas与转账收款相关概念

区块链是一个经济系统

  • 计算与存储系统都是稀缺的,区块链的工作需要消耗资源
  • 共识、trustless需要矿工的工作,而矿工需要激励
  • Transaction的执行有成本(gas),gas费成为矿工的奖励
  • ether是这个经济生态系统的通行货币
    在这里插入图片描述

关心的问题

  • 合约执行中的经济成本,即gas问题
  • 智能合约实现货币的流通,即转账收款功能

货币转换单位

在这里插入图片描述

合约持有ether

  • address.balance:合约可以有钱!
  • 合约与其他合约或者EOA之间可以转账
  • multisig钱包

gas和转账-函数调用的选项

  • 转账是与函数调用一起发生的。转账就是函数调用
  • 调用时加上调用选项在这里插入图片描述

gas、gasprice、gaslimit的解释-理清区别,搞懂关系

gas、gas fee、gas price

  • 实际的gas是完全由执行逻辑决定的,一个固定的逻辑的合约函数执行,gas没有变化
  • 有变化的是gas的price,是由交易者发起者在transaction中设定
  • gas price由市场定价
  • gas fee是gas*gasprice

gaslimit与gasleft()函数

  • 交易发起者设定最多消耗多少:gaslimit
  • 合约之间调用,调用者可以设定gaslimit
  • 区块本身有一个gaslimit
    gasleft()是以上因素作为限定,与当前gas消耗一起计算的结果

退款规则

  • 剩下没用完的gas会“退款”;
  • 如果可用gas耗尽时,会终止交易执行;
  • 交易失败时,已经用了的gas不退
### 使用强化学习优化区块链 Gas 费用 #### 方法概述 为了有效降低区块链上的交易成本并提高效率,可以采用强化学习来动态调整Gas费用。这种方法能够根据网络状态自适应地设置最优的Gas价格,在保证交易快速确认的同时减少不必要的开销。 在具体实现方面,可以通过构建一个基于马尔可夫决策过程(Markov Decision Process, MDP) 的模型来进行训练[^1]。该MDP定义如下: - **状态空间(State Space)**: 包含当前区块高度、待处理交易池大小以及最近几个区块内平均Gas消耗量等因素。 - **动作空间(Action Space)**: 设定一系列离散化的Gas费价位作为候选操作选项。 - **奖励函数(Reward Function)**: 奖励设计需综合考虑两方面的因素——一是尽快被矿工打包入块所获得的时间效益;二是因较低Gas花费带来的经济利益。因此,当一笔交易能在较短时间内完成且支付较少Gas时,则给予较高正反馈;反之则施加惩罚。 ```python import gym from stable_baselines3 import PPO env = gym.make('BlockchainTransaction-v0') model = PPO("MlpPolicy", env, verbose=1) # 训练模型 model.learn(total_timesteps=int(2e5)) def optimize_gas_fee(transaction_data): obs = transaction_data_to_observation_space(transaction_data) action, _states = model.predict(obs) return gas_price_from_action(action) ``` 此代码片段展示了如何利用Proximal Policy Optimization (PPO)[^4] 来创建和训练用于预测最佳Gas费率的动作策略。`transaction_data_to_observation_space()` 和 `gas_price_from_action()` 是两个辅助函数,分别负责将原始数据转换成适合输入给RL环境的形式,以及把由算法产生的action映射回实际可用的价格数值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值