diff --git a/cybertensor/__init__.py b/cybertensor/__init__.py index bfcc985..c06e648 100644 --- a/cybertensor/__init__.py +++ b/cybertensor/__init__.py @@ -30,7 +30,7 @@ nest_asyncio.apply() # Cybertensor code and protocol version. -__version__ = "0.2.2" +__version__ = "0.2.3" version_split = __version__.split(".") __version_as_int__ = ( (100 * int(version_split[0])) @@ -112,7 +112,7 @@ def __init__( __boot_symbol__: str = "PUSSY" __giga_boot_symbol__: str = "GPUSSY" -__networks__ = ["local", "bostrom", "space-pussy"] +__networks__ = ["local", "bostrom", "space-pussy", "space-pussy-graph"] __default_network__ = "space-pussy" @@ -158,7 +158,22 @@ def __init__( giga_token_symbol="GPUSSY", network_explorer="https://cyb.ai", address_prefix="pussy", - contract_address="pussy1ddwq8rxgdsm27pvpxqdy2ep9enuen6t2yhrqujvj9qwl4dtukx0s8hpka9", + contract_address="pussy1guj27rm0uj2mhwnnsr8j7cz6uvsz2d759kpalgqs60jahfzwgjcs4l28cw", +) + +__space_pussy_graph_network__ = NetworkConfigCwTensor( + chain_id="space-pussy", + url="grpc+https://grpc.space-pussy.cybernode.ai:1443", + fee_minimum_gas_price=0.01, + fee_denomination="pussy", + staking_denomination="pussy", + faucet_url="", + token="pussy", + token_symbol="PUSSY", + giga_token_symbol="GPUSSY", + network_explorer="https://cyb.ai", + address_prefix="pussy", + contract_address="pussy1j9qku20ssfjdzgl3y5hl0vfxzsjwzwn7d7us2t2n4ejgc6pesqcqhnxsz0", ) __contract_path__ = None diff --git a/cybertensor/chain_data.py b/cybertensor/chain_data.py index 91777de..4aa242d 100644 --- a/cybertensor/chain_data.py +++ b/cybertensor/chain_data.py @@ -446,7 +446,7 @@ class DelegateInfo: int ] # List of subnets that the delegate is allowed to validate on registrations: List[int] # List of subnets that the delegate is registered on - return_per_1000: Balance # Return per 1000 gboot of the delegate over a day + return_per_giga: Balance # Return per 1 gboot of the delegate over a day total_daily_return: Balance # Total daily return of the delegate @classmethod @@ -469,8 +469,8 @@ def fix_decoded_values(cls, decoded: Any) -> "DelegateInfo": ), validator_permits=decoded["validator_permits"], registrations=decoded["registrations"], - return_per_1000=Balance.from_boot(decoded["return_per_1000"]), - total_daily_return=Balance.from_boot(decoded["total_daily_return"]), + return_per_giga=Balance.from_boot(int(decoded["return_per_giga"]["amount"])), + total_daily_return=Balance.from_boot(int(decoded["total_daily_return"]["amount"])), ) @classmethod diff --git a/cybertensor/commands/network.py b/cybertensor/commands/network.py index ddca43b..00465cb 100644 --- a/cybertensor/commands/network.py +++ b/cybertensor/commands/network.py @@ -323,6 +323,7 @@ def add_args(parser: argparse.ArgumentParser): "min_burn": "sudo_set_min_burn", "max_burn": "sudo_set_max_burn", "max_allowed_validators": "sudo_set_max_allowed_validators", + "metadata": "sudo_set_subnet_metadata", } @@ -420,7 +421,7 @@ class SubnetHyperparamsCommand: Example usage: >>> ctcli subnets hyperparameters --netuid 1 - Subnet Hyperparameters - NETUID: 1 - finney + Subnet Hyperparameters - NETUID: 1 - space-pussy HYPERPARAMETER VALUE rho 10 kappa 32767 @@ -518,7 +519,7 @@ class SubnetGetHyperparamsCommand: Example usage: >>> ctcli sudo get --netuid 1 - Subnet Hyperparameters - NETUID: 1 - finney + Subnet Hyperparameters - NETUID: 1 - space-pussy HYPERPARAMETER VALUE rho 10 kappa 32767 diff --git a/cybertensor/contract/schema/execute.json b/cybertensor/contract/schema/execute.json index 1070417..384914b 100644 --- a/cybertensor/contract/schema/execute.json +++ b/cybertensor/contract/schema/execute.json @@ -157,6 +157,31 @@ }, "additionalProperties": false }, + { + "type": "object", + "required": [ + "set_delegate_commission" + ], + "properties": { + "set_delegate_commission": { + "type": "object", + "required": [ + "commission", + "hotkey" + ], + "properties": { + "commission": { + "type": "string" + }, + "hotkey": { + "type": "string" + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false + }, { "type": "object", "required": [ @@ -1425,10 +1450,37 @@ ], "properties": { "sudo_set_subnet_metadata": { + "type": "object", + "required": [ + "metadata", + "netuid" + ], + "properties": { + "metadata": { + "$ref": "#/definitions/Metadata" + }, + "netuid": { + "type": "integer", + "format": "uint16", + "minimum": 0.0 + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false + }, + { + "type": "object", + "required": [ + "sudo_set_subnet_owner" + ], + "properties": { + "sudo_set_subnet_owner": { "type": "object", "required": [ "netuid", - "particle" + "new_owner" ], "properties": { "netuid": { @@ -1436,7 +1488,7 @@ "format": "uint16", "minimum": 0.0 }, - "particle": { + "new_owner": { "type": "string" } }, @@ -1444,9 +1496,126 @@ } }, "additionalProperties": false + }, + { + "type": "object", + "required": [ + "sudo_set_root" + ], + "properties": { + "sudo_set_root": { + "type": "object", + "required": [ + "new_root" + ], + "properties": { + "new_root": { + "type": "string" + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false + }, + { + "type": "object", + "required": [ + "sudo_set_verse_metadata" + ], + "properties": { + "sudo_set_verse_metadata": { + "type": "object", + "required": [ + "metadata" + ], + "properties": { + "metadata": { + "$ref": "#/definitions/Metadata" + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false + }, + { + "type": "object", + "required": [ + "sudo_unstake_all" + ], + "properties": { + "sudo_unstake_all": { + "type": "object", + "properties": { + "limit": { + "type": [ + "integer", + "null" + ], + "format": "uint32", + "minimum": 0.0 + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false + }, + { + "type": "object", + "required": [ + "sudo_set_commission_change" + ], + "properties": { + "sudo_set_commission_change": { + "type": "object", + "required": [ + "change" + ], + "properties": { + "change": { + "type": "boolean" + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false } ], "definitions": { + "Metadata": { + "type": "object", + "required": [ + "description", + "extra", + "logo", + "name", + "particle", + "types" + ], + "properties": { + "description": { + "type": "string" + }, + "extra": { + "type": "string" + }, + "logo": { + "type": "string" + }, + "name": { + "type": "string" + }, + "particle": { + "type": "string" + }, + "types": { + "type": "string" + } + } + }, "Uint128": { "description": "A thin wrapper around u128 that is using strings for JSON encoding/decoding, such that the full u128 range can be used for clients that convert JSON numbers to floats, like JavaScript and jq.\n\n# Examples\n\nUse `from` to create instances of this and `u128` to get the value out:\n\n``` # use cosmwasm_std::Uint128; let a = Uint128::from(123u128); assert_eq!(a.u128(), 123);\n\nlet b = Uint128::from(42u64); assert_eq!(b.u128(), 42);\n\nlet c = Uint128::from(70u32); assert_eq!(c.u128(), 70); ```", "type": "string" diff --git a/cybertensor/contract/schema/query.json b/cybertensor/contract/schema/query.json index 3904130..11b2002 100644 --- a/cybertensor/contract/schema/query.json +++ b/cybertensor/contract/schema/query.json @@ -648,29 +648,6 @@ }, "additionalProperties": false }, - { - "type": "object", - "required": [ - "get_subnetwork_n" - ], - "properties": { - "get_subnetwork_n": { - "type": "object", - "required": [ - "netuid" - ], - "properties": { - "netuid": { - "type": "integer", - "format": "uint16", - "minimum": 0.0 - } - }, - "additionalProperties": false - } - }, - "additionalProperties": false - }, { "type": "object", "required": [ @@ -862,6 +839,99 @@ }, "additionalProperties": false }, + { + "type": "object", + "required": [ + "get_block_rewards" + ], + "properties": { + "get_block_rewards": { + "type": "object", + "additionalProperties": false + } + }, + "additionalProperties": false + }, + { + "type": "object", + "required": [ + "get_subnet_metadata" + ], + "properties": { + "get_subnet_metadata": { + "type": "object", + "required": [ + "netuid" + ], + "properties": { + "netuid": { + "type": "integer", + "format": "uint16", + "minimum": 0.0 + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false + }, + { + "type": "object", + "required": [ + "get_subnets_metadata" + ], + "properties": { + "get_subnets_metadata": { + "type": "object", + "properties": { + "limit": { + "type": [ + "integer", + "null" + ], + "format": "uint16", + "minimum": 0.0 + }, + "start_after": { + "type": [ + "integer", + "null" + ], + "format": "uint16", + "minimum": 0.0 + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false + }, + { + "type": "object", + "required": [ + "get_verse_metadata" + ], + "properties": { + "get_verse_metadata": { + "type": "object", + "additionalProperties": false + } + }, + "additionalProperties": false + }, + { + "type": "object", + "required": [ + "get_economy" + ], + "properties": { + "get_economy": { + "type": "object", + "additionalProperties": false + } + }, + "additionalProperties": false + }, { "type": "object", "required": [ diff --git a/cybertensor/cwtensor.py b/cybertensor/cwtensor.py index d83e14f..db08bda 100644 --- a/cybertensor/cwtensor.py +++ b/cybertensor/cwtensor.py @@ -82,7 +82,7 @@ class cwtensor: """Factory Class for cybertensor.cwtensor The cwtensor class handles interactions with the substrate cwtensor chain. - By default, the cwtensor class connects to the Finney which serves as the main cybertensor network. + By default, the cwtensor class connects to the Space-pussy which serves as the main cybertensor network. The cwtensor class in cybertensor serves as a crucial interface for interacting with the cybertensor blockchain, facilitating a range of operations essential for the decentralized machine learning network. @@ -95,7 +95,7 @@ class cwtensor: the ranking and incentive mechanisms within the network. Higher-ranked neurons, as determined by their contributions and trust within the network, receive more incentives. - The cwtensor class connects to various cybertensor networks like the main ``finney`` network or local test + The cwtensor class connects to various cybertensor networks like the main ``space-pussy`` network or local test networks, providing a gateway to the blockchain layer of cybertensor. It leverages a staked weighted trust system and consensus to ensure fair and distributed incentive mechanisms, where incentives (I) are primarily allocated to neurons that are trusted by the majority of the network. @@ -184,7 +184,7 @@ def determine_chain_endpoint_and_network( """ if network is None: return None, None - if network in ["local", "bostrom", "space-pussy"]: + if network in ["local", "bostrom", "space-pussy", "space-pussy-graph"]: if network == "bostrom": return ( network, @@ -195,6 +195,11 @@ def determine_chain_endpoint_and_network( network, cybertensor.__space_pussy_network__, ) + elif network == "space-pussy-graph": + return ( + network, + cybertensor.__space_pussy_graph_network__, + ) elif network == "local": return ( network, @@ -2347,7 +2352,7 @@ def metagraph( netuid: int, lite: bool = True, block: Optional[int] = None, - ) -> "cybertensor.Metagraph": + ) -> "cybertensor.metagraph": """ Returns a synced metagraph for a specified subnet within the cybertensor network. The metagraph represents the network's structure, including neuron connections and interactions. diff --git a/cybertensor/messages/network.py b/cybertensor/messages/network.py index b79ea89..765be05 100644 --- a/cybertensor/messages/network.py +++ b/cybertensor/messages/network.py @@ -16,6 +16,7 @@ # DEALINGS IN THE SOFTWARE. import time +import json from cosmpy.aerial.wallet import LocalWallet from cosmpy.crypto.keypairs import PrivateKey @@ -173,8 +174,9 @@ def set_hyperparameter_message( with console.status( f":satellite: Setting hyperparameter {parameter} to {value} on subnet: {netuid} ..." ): + _value = int(value) if parameter != 'metadata' else json.loads(value) sudo_msg = { - str(message): {"netuid": netuid, str(parameter): int(value)}, + str(message): {"netuid": netuid, str(parameter): _value}, } signer_wallet = LocalWallet( PrivateKey(wallet.coldkey.private_key), cwtensor.address_prefix @@ -187,7 +189,7 @@ def set_hyperparameter_message( f":exclamation_mark: [yellow]Warning[/yellow]: TX {tx.tx_hash} broadcasted without confirmation..." ) else: - tx = cwtensor.contract.execute(sudo_msg, signer_wallet, gas) + tx = cwtensor.contract.execute(sudo_msg, sender=signer_wallet, gas_limit=gas) console.print( f":satellite: [green]Processing..[/green]: TX {tx.tx_hash} waiting to complete..." ) diff --git a/cybertensor/metagraph.py b/cybertensor/metagraph.py index 7368264..497f718 100644 --- a/cybertensor/metagraph.py +++ b/cybertensor/metagraph.py @@ -265,7 +265,7 @@ def metadata(self) -> dict: } def __init__( - self, netuid: int, network: str = "finney", lite: bool = True, sync: bool = True + self, netuid: int, network: str = "space-pussy", lite: bool = True, sync: bool = True ) -> "metagraph": """ Initialize the metagraph object. diff --git a/cybertensor/mock/cwtensor_mock.py b/cybertensor/mock/cwtensor_mock.py index 47e1d19..52018b6 100644 --- a/cybertensor/mock/cwtensor_mock.py +++ b/cybertensor/mock/cwtensor_mock.py @@ -1322,7 +1322,7 @@ def get_delegate_by_hotkey( if self.neuron_has_validator_permit(uid=uid, netuid=subnet, block=block) ], registrations=[subnet for subnet, _ in registered_subnets], - return_per_1000=Balance.from_gboot(1234567), # Doesn't matter for mock? + return_per_giga=Balance.from_gboot(1234567), # Doesn't matter for mock? total_daily_return=Balance.from_gboot(1234567), # Doesn't matter for mock? ) diff --git a/requirements/dev.txt b/requirements/dev.txt index bc5d785..24302ca 100644 --- a/requirements/dev.txt +++ b/requirements/dev.txt @@ -9,4 +9,5 @@ ddt==1.6.0 hypothesis==6.81.1 flake8==7.0.0 mypy==1.8.0 -types-retry==0.9.9.4 \ No newline at end of file +types-retry==0.9.9.4 +jupyter>=1.0.0 \ No newline at end of file