Transaction Hash:
Block:
4389621 at Oct-19-2017 01:14:14 PM +UTC
Transaction Fee:
0.0000075609 ETH
$0.01
Gas Used:
42,005 Gas / 0.18 Gwei
Emitted Events:
95 |
Bitcoinereum.Transfer( _from=[Receiver] Bitcoinereum, _to=[Sender] 0x4bdbd9546b60874390fbb1128f4f55304b7ab568, _value=100000000 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x03DF4C37...CD8d68b0E | |||||
0x4BdBD954...04b7ab568 |
0.02031523653 Eth
Nonce: 8994
|
0.02030767563 Eth
Nonce: 8995
| 0.0000075609 | ||
0x829BD824...93333A830
Miner
| (F2Pool Old) | 5,066.319234955518131595 Eth | 5,066.319242516418131595 Eth | 0.0000075609 |
Execution Trace
Bitcoinereum.CALL( )
contract Bitcoinereum { string public symbol = "BTCM"; string public name = "Bitcoinereum"; uint8 public constant decimals = 8; uint256 _totalSupply = 0; uint256 _maxTotalSupply = 2100000000000000; uint256 _miningReward = 100000000; //1 BTCM - To be halved every 4 years uint256 _maxMiningReward = 5000000000; //50 BTCM - To be halved every 4 years uint256 _rewardHalvingTimePeriod = 126227704; //4 years uint256 _nextRewardHalving = now + _rewardHalvingTimePeriod; uint256 _rewardTimePeriod = 600; //10 minutes uint256 _rewardStart = now; uint256 _rewardEnd = now + _rewardTimePeriod; uint256 _currentMined = 0; event Transfer(address indexed _from, address indexed _to, uint256 _value); event Approval(address indexed _owner, address indexed _spender, uint256 _value); mapping(address => uint256) balances; mapping(address => mapping (address => uint256)) allowed; function totalSupply() constant returns (uint256) { return _totalSupply; } function balanceOf(address _owner) constant returns (uint256 balance) { return balances[_owner]; } function transfer(address _to, uint256 _amount) returns (bool success) { if (balances[msg.sender] >= _amount && _amount > 0 && balances[_to] + _amount > balances[_to]) { balances[msg.sender] -= _amount; balances[_to] += _amount; Transfer(msg.sender, _to, _amount); return true; } else { return false; } } function transferFrom( address _from, address _to, uint256 _amount ) returns (bool success) { if (balances[_from] >= _amount && allowed[_from][msg.sender] >= _amount && _amount > 0 && balances[_to] + _amount > balances[_to]) { balances[_from] -= _amount; allowed[_from][msg.sender] -= _amount; balances[_to] += _amount; Transfer(_from, _to, _amount); return true; } else { return false; } } function approve(address _spender, uint256 _amount) returns (bool success) { allowed[msg.sender][_spender] = _amount; Approval(msg.sender, _spender, _amount); return true; } function allowance(address _owner, address _spender) constant returns (uint256 remaining) { return allowed[_owner][_spender]; } function Mine() returns (bool success) { if (now < _rewardEnd && _currentMined >= _maxMiningReward) revert(); else if (now >= _rewardEnd) { _rewardStart = now; _rewardEnd = now + _rewardTimePeriod; _currentMined = 0; } if (now >= _nextRewardHalving) { _nextRewardHalving = now + _rewardHalvingTimePeriod; _miningReward = _miningReward / 2; _maxMiningReward = _maxMiningReward / 2; _currentMined = 0; _rewardStart = now; _rewardEnd = now + _rewardTimePeriod; } if ((_currentMined < _maxMiningReward) && (_totalSupply < _maxTotalSupply)) { balances[msg.sender] += _miningReward; _currentMined += _miningReward; _totalSupply += _miningReward; Transfer(this, msg.sender, _miningReward); return true; } return false; } function MaxTotalSupply() constant returns(uint256) { return _maxTotalSupply; } function MiningReward() constant returns(uint256) { return _miningReward; } function MaxMiningReward() constant returns(uint256) { return _maxMiningReward; } function RewardHalvingTimePeriod() constant returns(uint256) { return _rewardHalvingTimePeriod; } function NextRewardHalving() constant returns(uint256) { return _nextRewardHalving; } function RewardTimePeriod() constant returns(uint256) { return _rewardTimePeriod; } function RewardStart() constant returns(uint256) { return _rewardStart; } function RewardEnd() constant returns(uint256) { return _rewardEnd; } function CurrentMined() constant returns(uint256) { return _currentMined; } function TimeNow() constant returns(uint256) { return now; } }