Cryptocurrency Whitepaper (PDFDrive)
Cryptocurrency Whitepaper (PDFDrive)
Cryptocurrency Whitepaper (PDFDrive)
Hisyam
Advisers
www.gobyte.network
www.github.com/gobytecoin/gobyte
www.twitter.com/gobytenetwork
T.me/@gobytenetwork
This whitepaper is a living document and is improved and edited on a regular basis. The
strategies and ideas you will read about will continue to be added to, revised, and
improved as we move the project forward.
This whitepaper is divided in two parts. The first is introducing GoByte as it currently is
and as it will be. The second part is presenting the open source technologies we use as
the core of GoByte and what we are doing to improve upon them to realize our vision.
Milestones 6
What is GoByte? 11
- GoByte Pay 14
- Core features 15
- Future modules 22
- Miners, Masternodes, earning more GBX 22
- Anonymity 25
- Maximum supply 26
- Exchange and trading 27
- Roadmap 28
- Team 29
- Advisers 33
- Side team 35
- Strategy 38
- Target markets 41
- Distribution 46
- Strategy conclusion 53
Technical background
What is cryptocurrency? 56
- Different types of cryptocurrencies 58
- Main bottlenecks to Bitcoin 59
- Masternodes Network 68
GoByte Premine 85
Additional improvements 86
Security analysis 96
References 100
Milestones
Our mission at GoByte is to fulfill the vision that cryptocurrencies were meant to usher
in by creating a smart, powerful, and easy to use payment system that can be accessed
and used by anyone on the planet. GoByte is the future of payments and will be the
realization of the cryptocurrency revolution.
In November of 2017 a group of young developers from around the world got together
virtually to create their own cryptocurrency. They took an existing currency called Dash
with its foundations in Bitcoin and created a new coin and network called GoByte with
the goal of changing how money transacts in the world. Now that the coin is launched,
and the team has launched the GoByte Pay merchant payment system, the next step is
to further advance the technology of the system making it easier and easier for
consumers and merchants to use it on a daily basis. This will be achieved by launching
a concerted business development and marketing strategy to get the product into the
hands of merchants and consumers worldwide.
This document while extensively covering the technology upon which GoByte is based,
will cover the plans for the product of GoByte as well as the plans for penetrating the
market and getting GoByte to be an accepted form of payment with merchants and
consumers worldwide. We understand the realities of the marketplace and the forces
aligned against success, but we are determined to create a strategy that will result in
adoption and user levels never before accomplished in the world of cryptocurrency.
The first part of this document details our strategy for market penetration for the GoByte
currency and the GoByte Pay system. The second half of the document is a technical
deep dive into the tech behind the network based upon its origins in Dash.
The purpose of this white paper is to introduce you to our products, our vision, and our
strategy for dominating the world of payments. We welcome your thoughts and
feedback and we invite you to join our community.
Thank You
Bitcoin, Dash, and the cryptocurrency world
Dear Reader,
Thank you for joining us on this journey towards a better financial system for the world. We want to start
this document with the acknowledgement of our indebtedness to another cryptocurrency platform and
the world of cryptocurrencies in general.
Without the initiative of Satoshi Nakamoto and the team that made Bitcoin real and their continued work
to build upon that vision, GoByte and the currencies that came before it would not exist. We recognize the
power of the original Bitcoin creation and we honor the spirit of open source and the financial revolution
it embodies, by taking what exists and striving to make it better.
It is important for a reader of this white paper to understand the origins of the GoByte currency and the
origins of much of the technical content of this white paper. GoByte is a hard fork of the Dash
cryptocurrency and network. That means we took an existing open source licensed project and created
a copy of it and then over time have been writing our own code to make the project what we envision
GoByte needs to become to be the default method of payment in the world.
We must though, acknowledge our gratitude to the Dash team for the high-quality platform they built
that has allowed us to launch and build the GoByte network. Without their tireless work and dedication
to creating a powerful base upon which to build our vision, GoByte would have been much more difficult
to accomplish.
We want to thank and recognize the Dash team for their work. While we are pursuing a different path
technically and strategically, it is in the spirit of Open Source, that we share our code just as Dash shared
theirs. All of us collectively in the cryptocurrency community are working toward a better future for the
planet.
Thank you,
The GoByte Team
What is GoByte?
GoByte is an innovative, easy to use, and low fee cryptocurrency and digital payment system.
It has everything a consumer needs to use digital currencies and everything a merchant needs
to accept them.
If you are new to cryptocurrencies, we encourage you to use the resource list at the end of this
document to learn more about how they work and can be used.
GoByte was born in November of 2017. It is a fork or copy of an existing cryptocurrency system
called Dash. It is tested, secure, and powerful and has one of the fastest payment processing
engines available.
It also has the ability to be anonymous if a user chooses to use that functionality.
GoByte can be used on ecommerce websites and in stores. The GoByte Pay module makes it
easy for merchants to process payments from consumers in their store. A simple scan of a
barcode and a transaction can be completed quickly and securely.
A modular network
The GoByte Network is a modular network based on a powerful blockchain technology.
GoByte’s modules are developed independently from the primary blockchain and work
together to create a fast and secure network. The modular structure of the GoByte
Network means that modules can be updated independently without causing errors or
conflicts with other modules.
GoByte’s developers are working tirelessly to create new and innovative modules to
provide powerful new functionality for consumers, merchants, and developers. Every
module is developed by an independent team lead by a senior developer. The modular
design of the network gives developers a clean canvas upon which to build while they
can make use of the powerful functionality of the network.
A “module” is a part of the GoByte Network created for a specific purpose and functionality.
It assists the main network by reducing expansion to different domains of activity. This
allows GoByte to have many functional capabilities and doesn’t limit it to one central
purpose. Where other cryptocurrencies focus on a specific capability like anonymity,
transaction speed, or a vertical application, GoByte’s modularity has no limitations. The
GoByte network is growing at a very rapid pace adding up to 8 masternodes per day and
assuring the security and anonymity of the chain. Thanks to the modularity of the
system, the GoByte Network can maintain this growth rate for a very long time, which
allows the development team to enable new technologies and capabilities and ensure
the longevity of the platform.
GoByte Pay
What would a currency be if it couldn’t be used to buy and sell things? While many
cryptocurrencies are used to buy and sell things today, the process is difficult and often
counterintuitive and wrapped in an unprofessional interface. GoByte Pay takes
cryptocurrency payments to another level with a powerful and easy to use interface
designed for technically challenged merchants and consumers on desktop, web, and
mobile.
GoByte Pay is the first and most critical module of the GoByte Network. The GoByte Pay
module interacts directly with the blockchain, allowing it to create and execute
transactions which will later be confirmed by masternodes and miners. GoByte Pay is
designed as the central pillar of the network. The GoByte Pay module is required to be
fast, secure and easy to use and the development team dedicated to the module is
determined to always improve it with every iteration.
Core features
1. Send and receive GoByte (GBX) within seconds
2. Built with payment gateway and web wallet integration so that a merchant can account
for all of their transactions both on the web, in apps, and in stores
Another recurring issue with Bitcoin and other cryptocurrencies is large transaction fees.
GoByte Pay solves this problem by allowing $0 transaction fees inside the module after
a miner’s fee. All transactions inside the GoByte Pay module are done on the chain, not
server side, increasing security and eliminating possible threats.
Fees
The only fee that the GoByte Pay module subtracts, is the withdrawal fee for transactions
to GoByte addresses outside the module, including exchanges, local wallets and 3rd
parties. The withdrawal fee decreases up to 3% according to the user verification level
and is completely removed when withdrawing to masternode addresses which have an
ENABLED status.
The GoByte Pay module allows merchants to monitor and assign addresses to stores or
franchises as desired and eases the tracking of payments or potential issues regarding
bills or payments no matter the size of the merchant or company.
When a merchant owns a masternode, they enjoy $0 fees for all transactions and
withdrawals, because their transactions are confirmed by their masternode and as a
reward for being a contributor to the security and transaction processing capabilities of
the network.
At the time of this writing, the GoByte Pay module is capable of supporting more than
1,000,000 merchants with no impact on the transaction speed of the network because
of the number of masternodes on the network. As we scale the masternode network,
the number of merchants supported can be unlimited.
Apps
The GoByte Pay module also features a mobile app for IOS and Android which is directly
linked to the accounts registered in the GoByte Pay module. These apps share the same
capabilities of the desktop wallet which means they allow for $0 fees and easy access
to the wallets linked to a registered account.
Both GoByte Pay apps feature 1-click payments to addresses in the user’s address book,
QR code scans to load GBX addresses faster, and in the future will incorporate fingerprint
recognition and other biometric identity methods and technologies.
Terminal
Cryptocurrencies also suffer from a lack of adoption in retail stores. This is primarily
because existing payment systems rely on software and hardware terminals that do not
have cryptocurrency integrations. GoByte Pay will address this issue by providing an API
to help existing terminals easily connect to POS Terminals developed by the GoByte
Network or 3rd party developers. Integrations like this and others will connect with the
GoByte Pay wallet and generate invoices as QR codes, which will be scanned by the
customer using the GoByte Pay app and will confirm the transaction on the spot.
Existing payment processing terminals are often provided free of charge or inexpensively
to merchants or offered on a payment basis and the GoByte network will utilize all of
these methods to encourage adoption, especially as it relates to our geographically
focused initial marketing targets covered in the Strategy section of this document.
The POS Terminals will be directly connected to the merchant account inside the “Pay”
module, yet it won’t be able to manage that account or bring any modifications to the
account directly from the terminal. This way we want to prevent future token thefts from
unauthorized persons. The terminal will be allowed only to generate new addresses for
bills, inside the Pay module, and generate QR codes so the client can scan and pay with
his “Pay” app.
The client scans the QR code and selects to pay the amount with a 0 fee, thanks to the
“Pay” module. Once the transaction is broadcasted through the Masternodes, the POS
Terminal will show a confirmed message.
Thanks to the customization capabilities of the POS Terminals, we can expand even
further, by introducing our Crypto Debit cards which will allow multi-currency deposits.
The debit card will work through the GoBytePay module, allows deposits, transactions
and payments of other cryptocurrencies.
Technical specification for the terminals is available in the technology section of this
Ecommerce
GoByte Pay also comes with the ability to accept payments on the web in a shopping
cart or in a simple website. It is a highly secure method of payment and all of the features
of the GoByte Pay apps are available for online purchases.
The GoByte Pay Gateway is fast, transparent and secure. All transactions use a unique
address to make it easy to find what you need and they are secured and heavily encrypted
to stop hackers in their tracks. With GoByte Pay, you can provide your website customers
with the same power that in-store customers enjoy.
10. Supports multiple e-commerce applications out of the box with more upcoming
11. An API is available, so you can integrate GoByte Pay with any other system
12. You can charge users based on fiat currency like the US Dollar, so users can see
the what they are paying without having to do the math
15. Instant transaction for payments using the GoByte Pay wallet
16. Merchants can save a small fortune over what merchant account gateways charge
The GoByte Pay module is at the center of all of our technologies because it enables us
to build and grow a vast network of merchants and consumers using GoByte to save
and succeed.
Future modules
The GoByte team is examining a number of potential options to speed adoption of the
GoByte currency and will be announcing these as they make it onto our roadmap. One
of the options currently in the research phase is GoByte Swap.
While more and more people have begun to invest in and adopt cryptocurrencies, the
number of those currencies has made adoption for payment difficult. GoByte Swap will
use the open source Atomic Swap technology as the basis for a system that will make it
easy for consumers to swap out coins they already own in order to process a transaction
on the GoByte network.
This serves a number of purposes:
It makes it easier for consumers to manage and use the cryptocurrencies
they already have
Consumers will get more exposure to the power of GoByte and be encouraged
to adopt it to make it even easier to buy and sell using GoByte
The swaps technology will also make it easier for GoByte to be traded on
multiple exchanges, because a user can convert coins for buying and selling
and sending on the fly and exchanges may make use of the technology for
their own infrastructure
Increased liquidity means more trading volume and should have a positive
impact on the value of GoByte coins
This is just one example of the many modules our development team is considering.
Other modules will include integrations with other applications, markets, and ecosystems
as well as specialized applications for specific vertical markets. In addition, our APIs will
allow 3rd party developers to create their own modules for specific markets thus helping
to increase adoption worldwide.
If you have an idea that would be a great addition to the GoByte network, please reach
out to us on Discord or our other channels. We are a collaborative team and look forward
to hearing your thoughts.
Miners, masternodes, earning more GBX
We’ve mentioned masternodes a few times in this document but haven’t explained their
purpose and we have yet to explain mining as it relates to the GoByte network. A much
more technical explanation of both concepts is available in our Technology section, but
for the rest of us, this section will explain their importance.
In order for cryptocurrencies to be powerful, fast, decentralized, and secure, they require
a network of computers to provide processing power to the network. Satoshi Nakamoto
foresaw as well, that these computers would need to be rewarded in some way for
providing this power and so he created miners. Miners are computers that are tasked
with solving a complex math problem in order to create a block on the blockchain where
all transactions are stored in a virtual ledger (for an explanation of blockchains, please
see the resources section at the end of this document). This ledger is duplicated from
one block to the next ensuring that no “coins” can be spent more than once and that a
record of all transactions is always available. A mining machine can require a great deal
of processing power and therefore costs money and resources to build and run. For
providing these resources every time a miner solves the mathematical problem first and
records a block they are rewarded with coins associated with that block.
The advantage of mining for the GoByte network over many other networks is that it is
ASIC resistant. That means it can use a graphical processing unit to mine for the network
rather than very expensive ASIC processors that require even greater electrical
resources and are out of reach of common computers. GoByte has always been about
making it easier to use and to earn and that is reflected in our mining requirements.
On the other side of the processing and computing power equation are masternodes.
Masternodes require less computing power, but also help secure the network and record
transactions. Masternodes are less resource hungry, because they represent an
investment by a coin holder in the GoByte network. Every masternode owner is required
to hold 1000 GoByte coins and store them on their masternode server.
Then, on a regular basis (determined by the overall processing capabilities of the network)
they too earn more coins for validating transactions on the network. Masternodes help
keep the network fast and secure and so masternode owners are rewarded for their
investment in coins and processing with more coins being delivered to them on a regular
basis.
Currently the block reward or the number of coins created and distributed for every block
recorded is 15. This means that the miner receives 7.5 coins for every one they mine and
the chosen masternode is rewarded 7.5 GoByte coins. The number of coins rewarded
drops by approximately15% annually and a new block is created approximately every
150 seconds.
Masternodes and mining are a great way to contribute to the GoByte network and to be
rewarded for that contribution. We provide extensive help on our website for those that
would like to take part in mining or own a masternode.
Anonymity
GoByte payments can be if needed, completely anonymous using PrivateSend. This is
done by breaking up a payment into multiple parts and combining the parts with other
transactions. Most cryptocurrencies while they do provide a layer of simple anonymous
capabilities, can eventually be traced. This is true of Bitcoin and most of the major
altcoins, but GoByte takes anonymity to a very deep level providing complete protection
from detection. A detailed description of PrivateSend is available in the technical section
of this document.
Maximum supply
The maximum number of coins that will ever exist for GoByte is approximately 31.8
million. This means that after all coins are created, no more coins can ever be made.
This stands in stark contrast to fiat currencies, that are inflationary and are printed “as
needed” by the US Central Bank which creates a destabilizing effect on the value of the
US Dollar and has led to a number of financial crises.
It is estimated that mining will continue for approximately 243 years and provide an
extended time period as an incentive to miners and masternode holders to continue to
secure the network and process transactions.
Exchanges and trading
Cryptocurrencies are speculative, highly volatile and very risky. They may also be illegal
where you live. We encourage you to consult a licensed financial advisor and legal counsel
before investing in cryptocurrencies of any kind and do your own research. GoByte coins
are readily available for purchasing and trading on multiple exchanges and will become
more available as we continue to advance our network reach.
At the time of this writing, GoByte is available for purchase and trading on the following
exchanges and typically trades under the symbol GBX:
• Karsha Exchange
• Cryptopia
• Crypto-Bridge
• BarterDEX
• CoinExchange
• Stocks.Exchange
Roadmap
The following represents our planned innovations, but please be aware that development
timelines can be fluid and so while we provide some estimates of delivery, these release
dates can be delayed.
Team
The GoByte team is truly international. Our team members work virtually to create the
powerful platform and cryptocurrency you have available for your use today. Every
member of the team shares a core vision of making commerce easier and leveling the
playing field of finance for every participant in the world.
We can be reached via the following channels and welcome your feedback, ideas, and
community involvement. Without you we don’t really have a reason to exist, so please
dive in with us.
Discord: http://discord.gobyte.network
Reddit: https://www.reddit.com/r/GoByte/
Bitcointalk: https://bitcointalk.org/index.php?topic=2442185.0
Website: https://www.gobyte.network
Medium: http://medium.com/@gobytenetwork
Telegram: T.me/@gobytenetwork
Hisyam (LowKey)
Location: Malaysia
Position: Chief Executive Officer, Lead developer
One of the four founders. He is the lead core developer and the project manager. Hisyam
worked for years as a system administrator & network security specialist. He is on those
cryptocurrency enthusiasts, exciting coders and men of vision, who can push things to
the next level.
Linkedin: https://www.linkedin.com/in/mathieu-arbez-hermoso-a9b98383/
Twitter: https://twitter.com/MAH51323118
Syafiq is in charge of the public relations and the community management. He is also
helping on design, tech support and marketing strategy.
Linkedin: https://www.linkedin.com/in/mohd-abdul-syafiq-said-92377729/
Twitter: https://twitter.com/syafiq6191
Akif Rabbani
Location: Malaysia
Position: Chief Technology Officer, Lead developer of the GoByte Pay module, Head of
R&D Department
Akif is the lead developer of the GoByte Pay module. He leads a team of six Senior and
Junior developers who can work on different modules for GoByte. Akif is a great leader
and has the resources needed to lead the R&D department.
Linkedin: https://www.linkedin.com/in/akif-r-393575a4/
Twitter: https://twitter.com/akifrabbani
Advisers
Jarrad Williams
Location: USA, Miami, FL
Position: US General Manager
Jarrad is in charge of brand awareness in the United States. Jarrad is also in charge of
merchant applications in the United States.
Linkedin: https://www.linkedin.com/in/jarrad-williams-43912919/
Logan Kugler
Location: USA, Miami, FL
Logan is a serial entrepreneur who has built six companies and a vast network of world-
renowned business leaders. He has written about advances in technology, including
cryptocurrency, for dozens of national magazines including Popular Science, Forbes, PC
Magazine and Computerworld.
Linkedin: https://www.linkedin.com/in/logankugler/
Twitter: https://twitter.com/logankugler
Brad Nickel
Location: USA, Miami, FL
Brad Nickel has been in the startup world as a founder and adviser since 1997. He
founded one of the first SaaS providers, designed the core tech for network printing, and
has been a digital marketing executive for companies large and small.
Linkedin: https://www.linkedin.com/in/bradnickel/
Twitter: https://twitter.com/clickbrain
Website: https://blacknox.com/
Masoud Gheysari
Location: United Arab Emirates
Masoud Gheysari registered Karsha Business & Technology Inc. as a legal corporation
on November 2011. He started expanding this automatic exchange system, accepting
newly introduced cryptocurrencies and being one of the very first Bitcoin service
providers.
Linkedin: https://www.linkedin.com/in/khashmeshab/
Twitter: https://twitter.com/khashmeshab
Website: https://karsha.biz/
Side team
Azlan Shah
Location: Malaysia
Status: Contract on going
Azlan Shah was hired at the end of December 2017 to develop and release the mobile
apps of the GoByte “Pay” module. Azlan is a young developer with a lot of potential and
knowledge regarding the mobile platforms and an excellent partner for us . Azlan is in
charge of both IOS and Android apps for the “Pay” module.
Yugaindiran Marimuthu
Location: Malaysia
Status: Contract on going
Yugaindiran is a Junior Developer in the GoByte “Pay” development team that is lead by
Akif Rabbani. Thanks to his knowledge, Yugaindiran is a Senior Hardware Engineer at
the R&D department lead by Akif Rabbani. Yagaindiran is a key member for the further
development and research of the POS Terminals that will be connected with the GoByte
“Pay” module.
Long-term health
1 Larger and faster blocks. GoByte relies on a block size of 2MB and a block time
of 150 seconds. This effectively allows GoByte to handle a transaction volume
8x greater than Bitcoin’s.
Nodes express their acceptance of the block by working on creating the next block in the
chain, using the hash of the accepted block as the previous hash. Given that cryptographic
hashing functions are computationally infeasible to reverse, a hash match confirms that
the new block refers to the exact current state of the entire blockchain.
Nodes always consider the longest chain to be the correct one and will keep working on
extending it. If two nodes broadcast different versions of the next block simultaneously,
some nodes may receive one or the other first. In that case, they work on the first one
received, but save the other branch in case it becomes longer. The tie will be broken when
the next proof-of-work solution is found and one branch becomes longer; the nodes that
were working on the other branch will then switch to the longer one.
New transaction broadcasts do not necessarily need to reach all nodes. As long as they
reach a sufficiently large number of nodes, they will get into a block before long. Block
broadcasts are also tolerant of dropped messages. If a node does not receive a block, it
will request it when it receives the next block and realize it missed one.
Strategy
There is no point in putting in thousands of man hours to create a strong cryptocurrency
if you have no way to establish market dominance. The growth of cryptocurrency interest
in an investment context and the hyperaware levels of consumer interest in them, means
right now is the time for us to launch a strong strategic push into the market. No brand in
cryptocurrency has captured payments and none is as well positioned GoByte to do so.
That said, this is not an easy task. We will be using multiple strategies, tactics, and
targeting mechanisms in order to grow our brand and it will require a strong base of
talent and community enthusiasm to continue the growth we’ve already begun. We are
determined to make GoByte the number one choice for cryptocurrency payments
worldwide and we are ready to invest in the marketing and team needed to succeed.
Our goal to establish a strong presence in the payments market means we have multiple
sides to the market we must target and reach.
- Merchants
- Consumers
- Agents
- Merchant Franchisers
- Merchant Headquarters
- Investors
- Money transfer locations
To do that, we have to build interest and excitement about GoByte. We generally believe
that the fastest way to drive consumer adoption is through a presence in merchants and
through other online consumer promotions. We must have both sides of the equation if
we are going to succeed.
In order for that to happen, we have to build enough of a base of merchants in order to
have consumers see the presence of our brand in multiple retail locations. This need to
create two-sided demand means that in order for merchants to stay with us, they will
have to have enough customers using GoByte Pay to make it worth it to keep using and
promoting it.
Our approach to this is multi-pronged
- Geographic concentration targeting starting with South Florida and moving
northward to other locations in the United States and worldwide.
- In store marketing and promotions to get consumers to try and use GoByte
- Further promotions for transfers of funds via GoByte from South Florida
to family and friends in other countries
Every consumer that signs up needs if possible to have more than one use of GoByte
within their daily life. That can be either multiple merchants with whom they do business
in person or online or other methods of use including funds transfers across borders
and being an investor in GoByte on an exchange, as a masternode owner, or as a miner.
Our goal is to be able to reach new users with marketing communications for them to
be introduced to other ways of using GoByte. This is a critical component of our strategy
and will be a part of every introduction we do to customers with “How You Can Use
GoByte” type messaging at every brand exposure.
Part of the strategy is to connect with every new GoByte user by providing an incentive
to connect with the GoByte community, signup for a newsletter or get more involved in
what we are doing every time they use GoByte in a transaction.
We also will work with our merchants to provide incentives for them to offer discounts
and coupons for using GoByte. This becomes an easier task, because transactions are
free or have extremely low fees. Our merchants are already saving significantly with the
use of GoByte, so they have more margin with which to play for GoByte-based purchases
and the low-cost of the network means it is in their best interest to encourage more
customers to use it. On average they are paying about 3% per transaction and in many
retail businesses, 3% can be the difference between surviving and profitability.
As we progress through our marketing strategies, we will narrow our specific market
segment targets of both consumers and merchants by building out a series of marketing
messaging and advertising tests that will help us identify our most likely early adopters
for payments.
Merchants
In order to grow the use of GoByte, we will have to grow the number of merchants
available to take payments from consumers. Our success as a currency depends on
our ability to grow both sides of the market simultaneously and that is why we are
taking a multi-pronged approach to the growth of our merchant network.
Our targeting for merchants will be geographic, vertical, and mass market. We will use
sophisticated marketing techniques, referral programs, and networks of referral
partners and agents to grow our based of merchants.
Geographic
1. We have a business development, marketing and investor team in the area and
a beginning base of merchants to grow upon
3. The international nature of the area is perfect for spreading GoByte around the
world.
Millions of dollars are transferred into and out of South Florida to relatives,
friends, and ecommerce daily and the fees those transfers cost mean a GoByte
transfer option can be very attractive.
4. Much of the transfers of funds in and out of Miami happen in small retail outlets,
so we can target locations where immigrants currently frequent, but where
currently no funds transfer capabilities exist
6. Florida is also a tourist destination with the potential to also spread GoByte to
other regions of the country and the world by targeting tourist retailers to help
them and consumers save.
8. We will also expand geographically through north Florida and into the Atlanta,
Georgia region and then upwards throughout the United States.
Vertical
There are a number of verticalized currencies in the market today. These currencies
are meant to solve a problem for a specific industry, but when it comes to consumer
payments for things like cannabis treatments, healthcare, and other specialized
products and services, these currencies will likely struggle, because they do not serve
a consumer in any other scenario. So, while some currencies will succeed in those
markets, most will not generate the level of demand necessary to sustain a market.
GoByte’s approach is very different. We will target vertical markets for payments, but
these will only be as an initial adoption segment to get GoByte into consumers hands
and to get them used to using digital currencies. Once we have a consumer using our
currency, we will then encourage them to use it at other local, national, and ecommerce
merchants. We will build into our apps the ability to locate other merchants in the area
that accept GoByte Pay, as well as online sites.
We will also use advertising to drive customers to these vertical markets, because we
can more easily target them online with advertising and merchants will appreciate
that we are driving customers to their stores.
We are working through a number of potential vertical markets and have begun the
process of building partnerships with merchant account agents and others in
particular segments.
Our goal is to work through vertical markets while we are using geographic targeting
and will attempt to coincide expansion into those geographic areas in parallel.
Consumer to merchant promotion
We also will work to have our consumer clients that use GoByte help us to promote to
other merchants in their area, market, and on sites where they make purchases.
We will launch an easy to use and manage rewards system tied to the GoByte Pay
app to manage the rewards we will offer.
Mass market
While being very specific in our targeting both vertically and geographically, we will
also be promoting and marketing our solutions for merchants on a national and
international level. We will use targeted advertising, social media, content marketing,
public relations, and events to recruit merchants.
Consumers
We can book as many merchants as we want, but if we don’t have consumers to use
the GoByte network, then we will not be able to grow or sustain it.
Demographic targeting
As we engage with more and more users of GoByte, we will work to establish a
“persona” for consumers to be most likely to use our service so we can target them
with digital marketing. We need not only early adopters, but also adopters willing to
spread the word to other consumers in return for rewards.
We will use existing targeting metrics in social media to cross identify current
cryptocurrency exchange users and target them with our payment messaging. In
addition, we will be working to test messaging across social media and other digital
channels to determine what will work best for attracting and converting users.
Currently those most likely to invest in and use cryptocurrencies are younger men and
some younger women and so those will necessarily be some of our initial targeting
metrics, but we will seek to determine other demographics likely to adopt and use our
system via testing both online and through merchants.
Geographic targeting
Just as we are launching initial south Florida targeting in the United States for
merchants, we will also do the same for consumers. For specific strategies and
justifications for this approach, please see the geographic section under Target
Markets/Merchants.
Distribution
GoByte is currently a small organization and in order to grow our payments market
share, we will necessarily need to make use of partnerships to increase our market
penetration and distribution to merchants and consumers.
In this section we detail our strategies for going to market via partnerships that have
customers we want to target with GoByte and GoByte Pay.
ISO / Agents ISOs or Independent Sales Organizations and Agents offer merchant
account or credit card processing services to retail and online stores. For every
merchant they sign up for processing services, they retain a small percentage of all
processing charges that a merchant pays out of each transaction.
These organizations and sales people create recurring revenue streams for themselves
that can last for years. In order for GoByte to be able to utilize these same networks
for our services, we will need a rewards system that also equates to significant
revenue and will be using coin and masternode incentives to help them see the value
of GoByte over other forms of payment. The more the network grows, the more value
they will see in their coin rewards and so in turn, the more they will want to offer
GoByte Pay to merchants. Over time the value will far outstrip the revenue from credit
card transactions, but there is no reason they can’t sell both.
In recent years, the prospects for credit card processing revenue have begun to dwindle
for these sales and agent organizations, because companies like Stripe and Square
and others have begun to gain market share with simpler pricing and no middlemen.
This has resulted in less commissions and recurring revenue. This means these sales
people are nervous about the future of their business and the GoByte system can
provide an amazing opportunity for them to earn more.
We will also target service providers that work with merchants and provide them an
incentive to offer GoByte, include point of sale products, merchandising services, and
much more.
Integration
One of the benefits of building a system for payments and a cryptocurrency is the
ability to integrate that system with any other system that would be compatible. We
will examine the market for point of sale systems, accounting, and other business-
related systems that would be a strong fit for integrations. In the early stages we will
provide the integrations with major providers of systems that would be of value and
provide rewards to product and service providers that promote GoByte to their clients.
We will also offer an API for developers to make it easy to connect to the GoByte
payment system from their apps and website.
The goal is to make it as simple as possible for application developers and systems
with existing companies to be able to make use of the GoByte Pay system and to help
increase consumer adoption.
We have already developed a very strong community following for GoByte and we
plan to leverage that community to help us grow the brand. Each member of the
community has a vested interest in seeing us succeed and many have already offered
to support us as we launch our coordinated marketing strategy. Now that we have the
tools that consumers need to succeed, we are confident they will assist in our effort
to grow.
Our current community is very investment oriented and while that has sustained us
when things were difficult, we also must begin to expand our community to other
demographics. For example, most purchasing in the United States is handled by
females and targeting females for cryptocurrency spending can be difficult. In this
case, we will work to build community first around younger females that are more
likely to be willing to give GoByte a try. That targeting means that we need to build a
different type of community around the demographic and social networks that will be
our best targets. These campaigns will not only be organically driven, they will also be
advertising driven with the exception of Facebook.
One of the initial communities we build around our network will be one oriented to
people that would like to earn more money by referring GoByte to merchants and other
consumers. It will be critical though that we create the network where they already are
involved with communities including social networks and chat related applications.
All of this requires us to use strong content and social aggregation tactics to reach
each target demographic’s attention while providing a strong reason for each to
become involved. Again, this requires testing and strong data analysis in order for it
to be a success.
Just as we are planning geographic targeting in general, we will also use social
geographic targeting to increase the opportunity for consumers to use GoByte for
transactions
We also need to build a community for merchants. This will require a different type of
social strategy, but one that will be needed anyway.
We will require strong social media professionals and community managers to help
us grow our presence and as we grow the network and revenues, we will be able to
staff teams to make that possible. We will also identify strong social communicators
Event marketing
Because we are taking a geographically centric approach to marketing, we will also
make use of event marketing in our initial markets to build brand awareness and to
drive signups. Festivals, fairs, business conventions and more will all be part of the
overall strategy to drive adoption.
We will also use our own created events in partnership with our merchants, that will
be fun to attend and will encourage existing GoByte users to bring their friends.
Content marketing
Content marketing is the single most cost-effective type of marketing available to
digital marketers and we will use it in every facet of our strategies. From advertising
great content, to social promotion, we will work to constantly connect with merchants
and consumers by providing them with high quality, educational, and entertaining
content. Content marketing allows you to establish a relationship with consumers
over time, so they become comfortable with your brand, expertise, and capabilities.
We will generate written, video, audio (podcast), and graphical content to catch the
attention of our target markets. Most of the content we develop will be educational or
entertaining. Educational content allows us to establish ourselves as experts and as
a company that provides value to merchants and consumers while entertaining
content pushes our brand into the minds of consumers and makes it recognizable
and positive. Both can have a great deal of impact.
We will also create content that profiles our merchants to other merchants to show
how GoByte has made them successful and to consumers to help them connect with
more customers to use GoByte. Profiling our early adopter merchants will also allow
us to establish a stronger bond and loyalty with them and increase our ability to gain
referrals from other businesses.
Consumer content marketing
Our consumer content marketing will be a pretty even mix of entertainment and
educational. The educational content will be around the types of things that interest
our market whether it be crafts and cooking or wine and technology. Again, we will use
demographic targeting to determine our best bet and then provide them the content
that has the greatest impact in longer term conversions.
Advertising
Online advertising can be very cost effective, but if you don’t know what you are doing,
it can be very painful. We will be working with the best in social, search, and display
advertising to target and capture consumer interest. Most of our consumer
advertising will drive consumers to engaging content and our merchant advertising
will drive them to educational content about business.
We will also test campaigns to drive people straight to signups. Learning what search
terms and social interactions will drive conversions will be very important.
Effective advertising is all about data and we will be constantly analyzing our returns
over time to hone in on campaigns that are driving the most signups and eventually
revenue.
Public relations
Public relations is no longer about press releases. Today it is about getting great
stories written in targeted publications and we have a number of strategies we will
pursue using a professional PR agency.
The usefulness
NeoScrypt cryptocurrencies
- Anonymity
- Egalitarian PoW
- Memory bound functions
- Utilizes GPU cores for mining
- Defined as utilizing an application layer protocol
Non-ASIC cryptocurrencies
While more ASIC-Resistant than other coins, Non-ASIC cryptocurrency revolves around
an entirely different concept. Most utilize miner’s GPU or graphical processing unit for
mining. GPU accelerated computing is also an option since it is closer to analyzing
algorithms that are multithreaded. Some Non-ASIC cryptocurrencies utilize smart
contracts like Ethereum.
Main bottlenecks
to Bitcoin
1. Centralization
2. Network capacity (transactions per second)
3. Sustainability
4. Governance
Any decentralized payment system that wishes to achieve universal adoption and
solidify itself as a viable global currency must be built in such a way that its very
infrastructure addresses and solves all bottlenecks early on.
With this philosophy and unmet market demand in mind, we have decided to create
GoByte (GBX). GoByte is a community driven, open source and fully autonomous
cryptocurrency that places a strong emphasis on the very building blocks required to
create a complete payment system: it is secure, anonymous, trustless, scarce and
fungible with a very low-cost transaction pro le. It is designed to embody all that
Bitcoin as well as more advanced cryptocurrencies have grown to become as well as
to capture the economic value that is thus far inhibited by the systemic constraints
outlined above.
We will expand on these 4-main adoption and growth barriers and outline how GoByte’s
unique architecture seeks to resolve them.
Centralization
A network is considered centralized when either vast or absolute decision-making
power is vested in the hands of few individuals. We believe that in recent years, the
Bitcoin network has taken on a path of evolution that is incompatible with its founders’
original vision.
The first is the question of mining. Mining is the process by which individuals dedicate
computational resources to solving difficult mathematical problems. Upon solving the
aforementioned, a new block is found on the blockchain and with it newly pending
transactions are confirmed and cleared through. This process is known as Proof of
Work (or PoW) as it forces the miner to prove that they have done the necessary work
to verify the block, and the first miner to find a new block is compensated for their
efforts. This introduces an element of economic competition between miners and
prevents the network from being attacked as attacks become too costly and thus,
economically unviable.
Unfortunately, the Bitcoin protocol has introduced a mining algorithm that allows for
ASICs (Application-Specific Integrated Circuit) devices that can create a very large
number of hashes per second. This has created an unfair status quo whereby those
who can afford to purchase ASIC devices have a clear upper hand and those who
cannot are effectively excluded from participating in the network. Since every bitcoin
protocol enhancement needs to be approved with a 95% majority of miners, the top
X% of miners who own 95% of the mining power can either accept or veto any
suggestion that is brought before the community. This effectively overrules the
democratic nature that a decentralized network should be characterized by and
creates a disproportionate centralization of decision-making power. In order to prevent
such an occurrence, GoByte utilizes an advanced and fair hashing algorithm known
as NeoScrypt. NeoScrypt is well known for being a lightweight algorithm that can be
mined with very modest hardware devices.
This ensures that anyone can participate in the GoByte mining, whether they own a
smartphone or a supercomputer. As the name suggests, NeoScrypt is a further
development of Scrypt as described in Percival. It is aimed at increased security and
better performance on general purpose computer hardware while maintaining
comparable costs and requirements., which makes the development of a dedicated
ASIC device specifically designed to produce a large number of hashes per second
virtually impossible. This property is known as ASIC-resistance, and with it, we seek
to eliminate any barrier to entry for the average GoByte end user in terms of network
governance and promote absolute decentralization and democracy.
Network Capacity
Abstract
We outline an initial scaling mechanism for GoByte. After deployment and activation,
GoByte will be able to handle double the transactions it can currently handle. This
means that GoByte will be prepared for eight times the traffic of Bitcoin.
Motivation
Peer to peer electronic cash systems rely on the fact that they can be used with little
to no trust in a third party. We have also seen scaling issues have dramatic effects on
the usability of these systems. The current state of the GoByte network requires users
to trust that developers will deliver a scaling solution when needed. Implementation
of DIP1(Dash Core) allows users to actively participate in increasing the capacity of
GoByte.
In addition, scaling solutions take time to roll out. As such, developers are tasked with
rolling out scaling solutions four or five months before they are needed. Forecasting
network traffic growth is an impossible task. However, there are outside factors that
could accelerate this estimate. For example, a chain fork which is being discussed for
bitcoin may drive users to alternatives. Also, market actors can have a profound
impact on the use of GoByte, and do not necessarily announce their intentions for
proprietary reasons.
One more motivation is that adopting this proposal serves as a proof of concept of
GoByte’s governance system. It shows that proposals voted on by masternodes do
actually have real world results. It removes the need for users to trust in GoByte’s
proposal system.
Conventions
- 0x20000000 is the bit sequence 00100000000000000000000000000000 and is the
current version of dash blocks.
- 0x20000002 is the version used to signal acceptance of a consensus change rule. A
miner should use this version to signal acceptance of the miner and the masternode
for the block of a consensus rule change.
- We use % as it is used in C++. It is the remainder on division. So 7 % 3 is 7 modulo 3
and is equal to 1.
However, GoByte, with a 2MB block size means an attacking miner could include a
transaction that takes around 12 minutes to verify. If an attacker successfully gets an
attacking block in the chain then all nodes in the future will need to verify this block
when syncing. This attack is even more dramatic as block size increases. Paradoxically,
this attack could get so bad that it becomes impossible because propagation would
force an attacking block to be orphaned. Even if an attacking block is not included in
the main chain, trying to verify attacking blocks can have negative transient effects.
This attack is quadratic with respect to transaction size. As such, limiting transaction
size makes this attack impossible. Currently, transactions over a size of 100kB are
nonstandard and dropped by the network. A quadratic hashing attacking transaction
of size 100kB would take around 2 seconds to verify. Since transactions are processed
in parallel, a 2MB block full of 100kB attacking transactions would take from 4 to 8
seconds to process. For this reason, GoByte changed consensus rules so that blocks
with a transaction over 100kB are ruled invalid and orphaned.
Consensus protocol changes
- A block over 1MB is invalid.
To allow the network to scale we replace this rule with the two rules:
- A block over 2MB is invalid.
- A block with at least one transaction over 100kB is invalid.
Note the 100kB cap on transaction size will not necessarily be satisfied by old
blocks. For this reason, this new rule must only be enforced on blocks after activation
of the protocol change.
Observation
100kB transaction limit
This subsection is to only point out a possible efficiency of the 100kB transaction size
limit. Currently, transactions in the mempool already verified to be standard and thus
satisfy the size limit. It should then be possible that only transactions not seen by the
node would need to be checked to satisfy the 100kB limit. However, checking if a
transaction is in the mempool might take as long as verifying the size.
We remain in the DEFINED state until we either pass the starttime or the timeout.
GetMedianTimePast in the code below refers to the median nTime of a block and its
10 predecessors.
case DEFINED:
if (GetMedianTimePast(block.parent) >= timeout) {
return FAILED;
}
if (GetMedianTimePast(block.parent) >= starttime) {
return STARTED;
}
return DEFINED;
After a period in the STARTED state, if we’re past the timeout, we switch to FAILED. If
not, we tally the bits set, and transition to LOCKED_IN if a sufficient number of blocks
in the past period have bit1 set to 1.
Note that a block’s state never depends on its own nVersion; only on that of its
ancestors.
case STARTED:
if (GetMedianTimePast(block.parent) >= timeout) {
return FAILED;
}
if (thresholdreached) {
return LOCKED_IN;
}
return STARTED;
The protocol change is only in force when the first block is in an ACTIVE state.
Selection of parameters
For values of starttime and timeout, we implemented as follows:
The selection of a round consisting of 4032 blocks is made based on masternodes not
being randomly selected, rather they are in a queue. As such it can’t treat the sample of
masternodes as a simple random sample. At current time 4032 masternodes would
consist of a sample of around 87% of masternodes. This number is small enough that
the sample of masternodes are unique. If this number were larger then there would
be a chance that some masternodes would be sampled twice while others aren’t
sampled at all. This property is maintained as long as the number of blocks in a round
is under 90% of all masternodes. The number 4032 also has the property of being
equal to about a week of blocks.
Calculation of thresholdreached
Determination of thresholdreached
Given that bit1 will be 0 if mined by a non-DIP1 miner this actually targets activation
in the following cases.
Copyright
Copyright (c) March 25, 2015 - 2017 Dash Core Team. Licensed under MIT License
Copyright (c) November 16, 2017 - Present GoByte Core Team. Licensed under MIT License
MasterNodes
network
Full nodes are servers running on a P2P network, that allow peers to use them to
receive updates about the events on the network. These nodes require significant
amounts of traffic and other resources that carry substantial cost. As a result, on the
Bitcoin network a steady decrease in the amount of these nodes has been observed
for some time and as a result block propagation have been upwards of 40 seconds.
Many solutions have been proposed such as a new reward scheme by Microsoft
Research and the Bitnodes incentive program.
Masternodes are full nodes, just like in the Bitcoin network, except they must provide
a level of service to the network and have a bond of collateral to participate. Collateral
is never forfeit and is safe while the Masternode is operating. This allows investors to
provide a service to the network, earn interest on their investment and reduce the
volatility of the currency.
To run a Masternode, the node must store 1,000GBX. When active, nodes provide
services to clients on the network and in return are paid in the form of a dividend. This
allows the users to pay for the services and earn a return on investment. Masternodes
are all paid from the same pool of money, approximately 50% up to 80% of the total
block reward is dedicated to this program.
Due to the fact that the Masternode rewards program is not a fixed percentage and
the Masternode network nodes are fluctuating, expected Masternode rewards will
vary according to the current total count of active Masternodes and current block
reward distribution. Payments for a standard day for running a Masternode can be
calculated by using the following formula:
(n/t)*r*b*a
Where:
The cost associated with running a Masternode creates a hard and soft limit of active
nodes on the network. Currently with X (where X = Current GoByte coins in circulation),
only Y nodes (where Y = X/1000) could possibly be running on the network. The soft
limit is imposed by the price it costs to acquire a node and the limited liquidity on
exchanges due to usage of GoByte as a currency and not merely an investment.
Deterministic ordering
A special deterministic algorithm is used to create a pseudo-random ordering of the
Masternodes. By using the hash from the proof-of-work for each block, security of this
functionality will be provided by the mining network.
For(mastenode in masternodes){
current_score = masternode.CalculateScore();
if(current_score > best_score){
best_score = current_score;
winning_node = masternode;
}}
CMasterNode::CalculateScore(){
pow_hash = GetProofOfWorkHash(nBlockHeight); // get the hash of this block pow_hash_hash = Hash(pow_
hash); //hash the POW hash to increase the entropy difference = abs(pow_hash_hash - masternode_vin);
return difference;
}
The example code can be extended further to provide rankings of Masternodes also,
a “second”, “third”, “fourth” Masternode in the list to be selected.
Trustless quorums
Currently the GoByte network has ~705 (as of March 2018) active Masternodes. By
requiring 1,000 GBX collateral to become an active Masternode, we create a system in
which no one can control the entire network of Masternodes. For example, if someone
wants to control 50% of the Masternode network, they would have to buy 352,500
GoByte coins from the open market. This would raise the price substantially and it
would become impossible to acquire the needed GoByte.
With the addition of the Masternode network and the collateral requirements, we can
use this secondary network to do highly sensitive tasks in a trustless way, where no
single entity can control the outcome. By selecting N pseudo random Masternodes
from the total pool to perform the same task, these nodes can act as an oracle, without
having the whole network do the task.
Another example use for trustless quorums can include utilizing the Masternode
network as a decentralized oracle for financial markets, making secure decentralized
contracts a possibility. As an example, contract, if Apple Stock (AAPL) is over $300 on
Dec 31, 2016 pay public key A, otherwise pay public key B.
Bad actors could also run Masternodes, but not provide any of the quality service that
is required of the rest of the network. To reduce the possibility of people using the
system to their advantage nodes must ping the rest of the network to ensure they
remain active. This work is done by the Masternode network by selecting 2 quorums
per block. Quorum A checks the service of Quorum B, each block. Quorum A are the
closest nodes to the current block hash, while Quorum B are the furthest nodes from
said hash
Masternode A (1) checks Masternode B (rank 2300) Masternode A (2) checks
Masternode B (rank 2299) Masternode A (3) checks Masternode B (rank 2298)
All work done to check the network to prove that nodes are active is done by the
Masternode network itself. Approximately 1% of the network will be checked each
block. This results in the entire network being checked about six times per day. In order
to keep this system trustless, we select nodes randomly via the Quorum system, then
we also require a minimum of six violations in order to deactivate a node.
In order to trick this system, an attacker will need to be selected six times in a row.
Otherwise, violations will be cancelled out by the system as other nodes are selected
by the quorum system.
Table 1. The probability of tricking the system representing one individual Masternode as failing proof-
A cold mode is made possible by utilizing the secondary private key on two separate
machines. The primary “hot” client signs the 1,000GBX input including the secondary
signing private key in the message. Soon after the “cold” client sees a message
including its secondary key and activates as a Masternode. This allows the “hot” client
to be deactivated (client turned off) and leaves no possibility of an attacker gaining
access to the 1,000GBX by gaining access to the Masternode after activation.
Message: (1K GBX Input, Reachable IP Address, Signature, Signature Time, 1K GBX
Public Key, Secondary Public Key, Donation Public Key, Donation Percentage)
Every 15 minutes thereafter, a ping message is sent proving the node is still alive.
Message: (1K GBX Input, Signature (using secondary key), Signature Time, Stop)
After a time-to-live has expired the network will remove an inactive node from the
network, causing the node to not be used by clients or paid. Nodes can also ping the
network constantly, but if they do not have their ports open, they will eventually be
flagged as inactive and not be paid.
Propagation of the masternode list
New clients entering the GoByte network must be made aware of the currently active
Masternodes on the network to be able to utilize their services. As soon as they join
the mesh network, a command is sent to their peers asking for the known list of
Masternodes. A cache object is used for clients to record Masternodes and their
current status, so when clients restart they will simply load this file rather than asking
for the full list of Masternodes.
When mining on the network, pool software (websites that merge the efforts of
individual miners) use the RPC API interface to get information about how to make a
block. To pay the Masternodes, this interface must be extended by adding a secondary
payee to GetBlockTemplate. Pools then propagate their successfully mined blocks,
with a split payment between themselves and a Masternode.
To ensure that each Masternode is paid it’s fair share of the block reward, the network
must enforce that blocks pay the correct Masternode. If a miner is non-compliant their
blocks must be rejected by the network, otherwise cheating will be incentivized.
PrivateSend
We believe it is important to have a standard trustless implementation for improving
privacy of users in the reference client. Other clients such as Electrum, Android and
iPhone will also have the same anonymity layer implemented directly and utilize the
protocol extensions. This allows users a common experience anonymizing funds
using a well understood system.
To improve the fungibility and keep the integrity of the public blockchain, GoByte uses
an ahead-of-time decentralized trustless mixing strategy. To be effective at keeping
the currency fungible, this service is directly built into the currency, is easy to use and
safe for the average user.
Tracing CoinJoin by amounts
A common strategy in existing Bitcoin implementations of CoinJoin is simply merging
transactions together. This exposes the users to various methods of following the
users’ coins through these joined transactions.
To identify the source of the money, one simply has to add up the values on the right
until they match one of the values on the left. This gets exponentially more difficult as
more users are added to the mixer. However, these sessions can be retroactively de-
anonymized at any point in the future.
In other proposed implementations of CoinJoin, it is possible that a user anonymizes
money then eventually sends change from that transaction to an exchange or other
entity that knows the user’s identity. This breaks the anonymity and allows the entity to
walk backwards through that user’s transactions. We call this type of attack “Forward
Linking”:
In this example, Alice anonymizes 1.2BTC, which goes to two outputs, 1BTC and
0.2BTC. She then spends 0.7BTC from the 1BTC output, receiving change of 0.3BTC.
That 0.3BTC then goes to an identifiable source, confirming Alice also spent the
0.7BTC in the prior transaction.
In the second example, Alice buys 1.2 BTC from coinbase , then anonymizes this
amount into a 1BTC output. She then spends the 1BTC, receives change in the amount
of 0.3BTC and then combines that with her 0.2BTC earlier change.
By combining the change from the anonymous transaction (0.3BTC) and the change
she received from the CoinJoin transaction, you can link the entire history before and
after, completely breaking the anonymity.
Improved privacy and denial-of-service (DOS)
resistance
PrivateSend uses the fact that a transaction can be formed by multiple parties and
made out to multiple parties to merge funds together in a way where they cannot be
uncoupled thereafter. Given that all PrivateSend transactions are setup for users to
pay themselves, the system is highly secure against theft and users coins always
remain safe. Currently to mix using PrivateSend requires at least three participants.
To address possible DOS attacks, all users submit a transaction as collateral to the
pool when joining. This transaction will be made out to themselves and will pay a high
fee to miners. In the case when a user submits a request to the mixing pool, they must
provide collateral at the beginning of this exchange. If at any point any user fails to
cooperate, by refusing to sign for example, the collateral transaction will automatically
be broadcasted. This will make it expensive to do a sustained attack on the privacy
network.
Passive anonymization of funds and chaining
PrivateSend is limited to 1,000GBX per session and requires multiple sessions to
thoroughly anonymize significant amounts of money. To make the user experience
easy and make timing attacks very difficult, PrivateSend runs in a passive mode. At
set intervals, a user’s client will request to join with other clients via a Masternode.
Upon entry into the Masternode, a queue object is propagated throughout the network
detailing the denominations the user is looking to anonymize, but no information that
can be used to identify the user.
Security considerations
As transactions are merged, Masternodes can possibly “snoop” on users’ funds as they
pass through. This is not considered a serious limitation due to the requirement for
Masternode’s to hold 1,000GBX and the fact that users utilize random Masternodes
that they select to host their joins. The probability of following a transaction throughout
a chaining event can be calculated as follows:
Attacker Controlled Depth Of The Chain Probability of suc- GoByte Required
Masternodes / Total cess
Masternodes (n/t)r
Table 3. The probability of follow a PrivateSend transaction on the network given the attacker controls N Nodes.
Where:
n is the total number of nodes controlled by the attacker t is the total number of
Masternodes in the network
r is the depth of the chain
Considering the limited supply of GBX (943 thousands at the time of writing, March
2018) and the low liquidity available on the market, it becomes an impossibility to
attain a large enough number of Masternodes to succeed at such an attack.
Instead of a user submitting the inputs and outputs directly into the pool, they will pick
a random Masternode from the network and request that it relays the inputs/
outputs/signatures to the target Masternode. This means that the Masternode will
receive N sets of inputs/outputs and N sets of signatures. Each set belongs to one of
the users, but the Masternode can’t know which belongs to which.
Instant transactions via InstantSend
By utilizing Masternode quorums, users are able to send and receive instant irreversible
transactions. Once a quorum has been formed, the inputs of the transaction are
locked to only be spendable in a specific transaction, a transaction lock takes about
four seconds to be set currently on the network. If consensus is reached on a lock by
the Masternode network, all conflicting transactions or conflicting blocks would be
rejected thereafter, unless they matched the exact transaction ID of the lock in place.
This will allow vendors to use mobile devices in place of traditional POS systems for
real world commerce and users to quickly settle face-to-face non-commercial
transactions as with traditional cash. This is done without a central authority. An
extensive overview of this feature can be found in the InstantSend white paper.
For the IC Card Reader, the terminal supports 3V or 5V card and ISO7816CPU card,
conform to PBOC and EMV standards.
The Contactless Card Reader, which is optional for the merchants, has the following
specifications: 13.56MHZ support type A/B, mifare one card.
We rely on the QR codes in order to ease the copy-pasting of the address and amount
needed to be sent, so the terminal will have a built-in 1D/2D barcode reader.
As from communication point of view, the terminal will use GPRS connectivity.
As for the battery and size, the terminal will have a built-in rechargeable lithium battery:
7.4V 2600mAH and should be around 186.5 mm X 80.6 mm X 52.3mm in size.
Certifications that the terminal own are:
For CPU and Memory, a high performance 32-bit security processor and 8MB large
capacity memory will be used.
So, by creating a Crypto card for the Crypto world that is able to operate inside the
Crypto world only should be a huge step ahead for GoByte and Crypto world.
The expected price of the POS Terminal is around 150 USD, without the shipping fees,
and the expected supply should be of around 150000 Pieces per Month.
The merchants will not pay any installation/customization fee, except the POS
Terminal price & shipment fee, the installation of the “Pay” module and any update or
customization will be supported by the GoByte Network team.
So, we hope that this way we will provide an easy way for physical merchants to
accept payments on the go, from restaurants to cloth stores also to allow us the
creation of our own Crypto cards for the GoByte Network.
GoByte premine
Distribution
- Total premine: 850 000 GBX
- We allocated for masternode auctions and paid advertising, an amount of
150 000 GBX
- We allocated for bounties and events, an amount of 30 000 GBX
- We allocated for further development and growth of GoByte’s Network, an
amount of 570 000 GBX
- We allocated for developer’s personal use, an amount of 100 000 GBX
Due to the complexity and die size required to create an ASIC for mining NeoScrypt, we
expect that it will take considerably longer than it did in Bitcoin, allowing for hobbyists
to take part in the mining for a longer period of time. We believe this is highly important
for good distribution and growth of a cryptocurrency.
Another benefit of the chaining hashing approach is high end CPUs give an average
return similar to that of GPUs. Also, GPUs have been reported to run 30-50% cooler,
with less wattage than the Scrypt algorithm used by most current cryptocurrencies.
Mining supply
A different approach to restricting the inflation of mining is taken in GoByte, using a
15% reduction of the supply per year. This is done instead of the halving implemented
by other currencies. In addition, supply of each block is directly tied to the number of
miners on the network; more miners results in lower mining rewards.
To motivate miners to participate in the mining process and cover their costs, the first
miner to find a new block is compensated for their efforts. This introduces an element
of economic competition between miners and prevents the network from being
attacked as attacks become too costly and thus, economically unviable. As GoByte
uses the ASIC-resistant NeoScrypt Algorithm previously mentioned, any party can
participate in the mining process regardless of their device type and hardware
capabilities, which prevents the concentration and centralization of decision-making
power in the hands of the few and enables a true democratic process.
GoByte’s block time is set at 150 seconds, meaning the network aims for blocks to be
created every 150 seconds. This aim is facilitated by what is known as a difficulty
retargeting algorithm, which increases or decreases the difficulty of finding a block in
proportion to the total hashing rate (processing power) being contributed to the
network. If, for example, the hashing rate suddenly doubles, the difficulty will increase
to ensure that blocks are not recovered every 30 seconds and vice versa. This is of
extreme importance as we have witnessed the danger of a frozen blockchain with
Bitcoin, whose retargeting algorithm adjusts every 2016 blocks, or every 14 days at
10 minutes per blocks. This means that if mining power suddenly drops (due to
lowered mining profitability for instance), it will take the network two weeks to lower
the difficulty accordingly, during which time the blockchain could grind to a halt. To
prevent this from happening, GoByte’s algorithm adjusts the difficulty level every block,
or every 150 seconds.
As we have seen, the risks of high inflation and its devaluing implications on national
currencies, GoByte attempts to reverse this trend by offering an ever-decreasing
emission rate, which ensures it remains a disinflationary currency in nature. This was
designed to preserve and protect GoByte’s innate coin value. Please refer to the table
below to see GoByte’s coin emission schedule per stage (or Epoch); the distribution of
miners’ rewards vs. masternode operator rewards are listed next to each stag.
Reward Allocation or PoW Block Rewards (starting on November 16th, 2017 | for 7 years):
The following are changes to the reward allocations that include implementation of governance and
the budget for governance.
On Block 1 (Genesis Block), 850,000 GoByte were created (premine) in order to set up
3 masternodes and support and stabilize the GoByte network (at 1,000 GoByte per
node collateral). These are scheduled to be used later in 2018 and will not be used in
any other way than helping the further development of the GoByte Network.
Lastly, block maturity is defined as the minimum age of a block, in terms of blocks
rather than standard time units, before it is safely considered to be part of the chain.
The logic behind this is that since each block validates all of its predecessors, the more
blocks are added on top of a block, the more valid and safe for consideration it
becomes. The standard block maturity for Bitcoin is 101 blocks. While GoByte’s block
maturity is set at 111 blocks, given GoByte’s far quicker block time at 2.5 minutes, a
block can be considered mature in under 5 hours, giving the network a very solid
foundation for security references.
DGW was authored by Evan Duffield, the developer and creator of X11/Darkcoin/
Dash, as a response to a time-warp exploit found in Kimoto’s Gravity Well.
In concept, DGW is similar to Kimoto Gravity Well, adjusting the difficulty levels every
block (instead of every 2016 blocks like Bitcoin) by using statistical data of the last
blocks found. In this way block issuing times can remain consistent, despite high
fluctuations in hash power. However, it doesn’t suffer from the time-warp exploit.
Version 2.0 of DGW was implemented in Darkcoin/Dash from block 45.000 onwards
in order to completely alleviate the time-warp exploit.
Version 3.0 was implemented on GoByte from block 700 on November 17 of 2017 to
further improve difficulty re-targeting with smoother transitions. It also fixes issues
with various architectures that had different levels of floating-point accuracy through
the use of integers.
NeoScrypt algorithm
Password based key derivation function (KDF) is a deterministic algorithm used to
derive a cryptographic key from an input datum known as a password. An additional
input datum known as a salt may be employed in order to increase strength of the
algorithm against attacks using pre-computed hashes also known as rainbow tables.
The derived key length may be specified usually, and one of the most popular uses of
KDFs is key stretching. It increases effective length of a user password by constructing
an enhanced key to provide with a better resistance against brute force attacks.
Another popular use is password storage. Keeping user passwords in unencrypted
form is very undesired as it may be possible for an attacker to gain access to the
password file and retrieve the passwords stored immediately. Brute force attacks
may be the only possible approach against strong KDFs. This kind of attack can be
parallelized usually to a great extent. High requirements on computational resources
such as processor time and memory space allow to reduce parallelization efficiency
and keep these attacks expensive far beyond reasonable limits.
The default memory segment size for the 32-bit implementation is 128 bytes. r is the
segment size multiplier. p is the computational multiplier. They may be also described
through rfactor and pfactor respectively.
The Scrypt core engine has no provisions for key stretching or compressing as well
as salting, therefore additional cryptographic functions need to be deployed. In case
of cryptocurrencies, a typical configuration operates with 80 bytes of input data (block
header) which is also a salt. It is passed to PBKDF2, a password based KDF capable
of deriving variable length keys with salting. It works with SHA-256, a cryptographic
hash function delivering digests up to 32 bytes in size through 64 internal rounds. It
doesn’t support keyed hashing, therefore a pseudorandom function (PRF) such as
HMAC is required, and the whole big-endian construction may be called PBKDF2-
HMAC-SHA256. It feeds r * 128 bytes of derived data to the Scrypt core and receives it
back after mixing to be used as a salt for another PBKDF2- HMAC-SHA256 run which
compresses 80 bytes of input data into 32 bytes of hash.
NeoScrypt specification
Although a very innovative design when launched, Scrypt has developed certain
vulnerabilities. The first announced differential cryptanalysis of Salsa20/8 by Tsunoo
in 2007 did not deliver any advantage over 256-bit brute force attack, but the following
research by Aumasson reduced time complexity to break it from 2255 to 2251 with
50% success probability. It was improved by Shi in 2012 to 2250. Although this is not
critical yet, better attacks on Salsa20/8 may be developed in the future.
PBKDF2 is a very popular KDF and may be configured to require considerably large
amounts of processor time, but it does not require complex logic or significant
amounts of memory to operate. Therefore, brute force attacks can be carried out on
general purpose hardware such as GPUs or custom designs (ASICs) with reasonably
low costs. SHA-256 also allows numerous performance optimizations in this context.
It is also worth to mention that Scrypt relies very little on PBKDF2- HMAC-SHA256
strength as it is configured to run in the fastest 1-iteration mode even though 1000-
iteration minimum advised in general.
NeoScrypt addresses these issues. The core engine is configured to employ non-
reduced Salsa20 of 20 rounds (Salsa20/20) as well as non-reduced ChaCha20 of 20
rounds (ChaCha20/20). Both of them are used to produce the final salt as their
outputs are XOR’ed into it. They may be configured to run either in series or parallel
depending on application objectives. The default NeoScrypt configuration is (128, 2,
1). A single instance of NeoScrypt utilises (N + 3) * r * 128 bytes of memory space,
i.e. 32.75Kb, in series mode or (2 * N + 3) * r * 128 bytes, i.e. 64.75Kb, in parallel mode.
Every run of the NeoScrypt core engine executes Salsa20/20 and ChaCha20/20 1024
times each which might seem inferior to 4096 times of Salsa20/8 of the Scrypt core
engine. However, NeoScrypt operates with double the memory segment size requiring
larger temporal buffers, also with higher round count of each stream cipher iteration
as explained above. If approximated to abstract load/ store units, NeoScrypt is 1.25
times more memory intensive than Scrypt. There are no known successful attacks on
non-reduced Salsa20 and ChaCha20 other than exhaustive brute force search.
NeoScrypt replaces SHA-256 with BLAKE2s which is a further development of BLAKE-
256 [10], one of 5 NIST SHA-3 contest finalists. Based upon ChaCha20, operates with a
lower round count of 10, supports keyed hashing, is native little endian and faster
significantly than SHA-256 and even BLAKE-256. It could be interfaced directly to
PBKDF2 with no need of HMAC. However, PBKDF2 constructs derived keys using
blocks. It means a minor change in an input datum, such as nonce increment, may
not result in an entirely different derived key. A replacement KDF has been developed
to address this issue.
FastKDF is a buffered password based KDF which also supports salting. It operates
with 2 primary buffers for password and salt each. They must be a power of 2 in size
and not less than any input (password, salt) or output (derived key) data. The default
configuration works with 256-byte buffers. Password and salt are loaded initially into
these buffers in a repetitive manner until the end of buffer is reached. The salt buffer is
modified through operations while the password buffer remains constant. The buffer
pointers are set to zero (start) on the first run. When a PRF chosen delivers a digest,
a sum of all its bytes modulo buffer size defines the next buffer pointer. The digest is
XOR’ed into the salt buffer at the new buffer pointer and the next iteration starts. If a
read or write operation goes past a buffer end, it is continued from the buffer start.
BLAKE2s is configured to operate with 64-byte input (password), 32-byte key (salt)
and 32-byte output (digest). When the final FastKDF iteration is completed, the
password buffer using zero buffer pointer is XOR’ed into the salt buffer using the last
buffer pointer to produce the derived key of length required which is copied into the
output buffer. FastKDF-BLAKE2s is configured to run through 32 iterations by default.
It is little endian for easier deployment and additional minor performance advantage
on popular general-purpose computer hardware.
Atomic swaps
We regard the explosive growth of the cryptocurrency space to be indicative of a
growing market-wide demand for decentralized and economical solutions across a
multitude of industries. As a result, over the past few years, cryptocurrency projects
have emerged tending to specific niches, industries and utility sets. These range from
agriculture, construction, health, banking, law, manufacturing, energy, communication
industries and others. Rather than hold the belief that there will be one single coin to
rule them all, we view the current landscape as rapidly and divergently evolving.
With this in mind, instead of restricting a users choice of currency, we have decided to
accommodate their broad desire by introducing the Atomic Swaps mechanism. An
Atomic Swap is the process by which user A who owns coin X can exchange their coin
with user B owning coin Y both having separate blockchains, in a fast, secure and
trustless way. Once an exchange rate is agreed upon by both parties, a cross- chain
swap takes place. It’s the decentralized world’s equivalent of over-the-counter («OTC»)
trades as they don’t require a 3rd party. Furthermore, atomic swaps have the added
benefit of utilizing a very specific type of smart contract, being hash and time lock.
This means that user A sends their funds to a certain address which then locks up the
funds. If user B then fails to come through by a certain agreed upon time, the funds
are unlocked, the transaction is reversed by the blockchain and user A gets their funds
back.
In our implementation of Atomic Swaps, we wish to take the concept further and
make it a component of a payment transaction. Rather than limiting users paying for
something using GoByte Pay to just GBX, our goal is to create a seamless method for
a shopper that has ETH to be able to purchase from a GoByte merchant by connecting
their wallets and creating a swap with other users or a GoByte bank in real time.
Atomic Swaps will be implemented in the near future.
In order to perform an on-chain atomic swap between two cryptocurrencies, there are
several prerequisites to factor in. Both chains must support:
On-Chain atomic swaps are mostly useful in cases where users want to perform an
exchange that is characterized by a larger trade that is not subject to a particular time
constraint. Since the process involves on-chain transactions, the speed of the process
is bound by the mining or staking of blocks on both chains, and the slower of the two
at that. This can take roughly an hour when transacting with the Bitcoin blockchain.
Additionally, users must pay transaction fees for both the swap and the redemption
transaction on each chain, which can have a non-trivial cost with Bitcoin.
Furthermore, since these swaps are on-chain, there are some privacy implications
that users should be aware of. The swap transaction on each chain include the same
hashed value, meaning that anyone who surveils on the corresponding blockchains
can link the coins on one side of the swap to the coins on the other side. Further down
the road, GoByte will implement solutions for off-chain transactions that will eliminate
the concerns outlined above.
Security analysis
A vital assumption in proof-of-stake models is assuming honest nodes hold at least
51% stake and are online and participating in staking. This is also required in the
security analysis.
Honest nodes should always build upon the latest valid block containing the lowest
weighted value from hash-chain A. Usually this will result in a chain composed of
blocks containing consecutive winning hash-chain A weighted reveal values.
In practice the node implementation currently uses a matrix of received blocks (a
buffer) which sits in memory and is x blocks in length, sat atop the chain.
Buffer rules
1. Always build upon block sequence with consecutive lowest adjusted hashchain A
value whilst in the buffer (x blocks deep) - this may result in nodes discarding later
blocks in the buffer and building upon a ‘stronger’ but shorter chain on occasion when
a block arrives late
2. New blocks arriving deeper than x are ignored.
Fork rules
True chain forks may only occur which are more than x blocks deep and less than y
blocks from the current blockheight (assuming signatures are correct on both sides
of the fork), where x is the length of the buffer and y is the number of blocks of replay
attack protection offered by B set of hash-chains.
1. For a fork (deeper than x, above y blocks) choose the side of the fork with the most
cumulative stake in the reveals in the blockheader of each block. Nodes should not
consider forks: deeper than y, which cross an epoch transition, or which grow the
chain forward into the future fraudulently (assessed by NTP-corrected blockheader
timestamps).
2. New stakers should always build on top of the chain with highest stake score as
per 1.
Double spend
Conventional double spending attempts may occur by displacing one transaction with
another different transaction which is confirmed earlier into a block. To give certainty
that the transaction history of the chain may not change by a fork up to depth y blocks,
it is necessary then to wait for y confirmations.
Nothing at stake
When a fork happens, honest nodes should build on top of the strongest chain by
sequence of stake-weighted hash-chain A reveal. However, there is no theoretical
reason for nodes to not also try to build on top of weaker permutations. As new blocks
require signatures from winners, it is possible for the whole network to see a node
trying to build on top of a wrong chain. It is possible to put a penalty on this, for
example all coins of that attacker can be transferred to all honest nodes, creating an
incentive to behave honest but also another incentive to participate in staking. The
authors feel this attack is theoretical as honest node behaviour in the event of two
reveal votes arriving from a particular stake validator is to discard the second vote
automatically.
Long range attacks / Hash replay attack
In this case, an attacker tries to make a completely different fabricated chain in his
favour from an earlier blockheight.
1. The attacker must create a chain to the current blockheight with valid winning
blocks (each containing a valid XMSS signature of the blockheader from the victorious
stake validator).
2. As the epoch progresses the hash indexes of earlier hash-chain A reveals are
known by the network. To prevent earlier stake validator votes being replayed to falsely
demonstrate stake validator support for the attacker fork, a second reveal hash for
each validator (hash-chain B reveal hash) must also be supplied. Given we set a reorg
limit of y blocks we can be sure that this strategy is unlikely to succeed. The only
mitigation the attacker can achieve is to remove stake validator reveal votes he is
unable to replay into the forged block - but this will result in less total amount of
committed stake per block, which in turn means honest nodes will continue to follow
the correct/ original chain during a fork recovery process.
As the honest nodes will accept a fork less than x blocks deep, the attacker wants to
construct a fork of at least x blocks deep. Furthermore, he needs to win each block
honestly for two reasons: to get more cumulative stake weight and to be able to
construct a valid signature, as he does not get that from other winners. Assuming the
attacker has about 50% stake (this means we assume the strongest attacker
possible), his probability of winning all x block equals (1/2)x. Having the correct hash
reveal of chain B, which we take 50 chains, of k stakers, equals at most x50k. So the
total success probability of attacking the chain and «stealing» the hash- reveals of an
honest staker equals
By taking x = 10 blocks deep buffer and only k = 10 stakers, we get a success probability
of 2−33. In other words, the attacker has to compute 233 hashvalues (similar to
mining) to get a correct malicious blockchain. This will take significant amount of time
on current computers. On top of that, the honest chain will also move forwards, which
means he needs to do this attack faster than one new block creation. We do not see
this possible. In the future, both value x and number of chains in set B can be increased
easily for improved security.
Block withholding attacks
A block withholding attack is an attack in which the block winner does not reveal that
he won the block, but withholds it to his advantage instead. A block withholding attack
in our protocol cannot occur by keeping the block more than x blocks, as after that no
reorg changes are allowed to the main chain which then becomes immutable.
Withholding a winning reveal hash costs the attacker the block reward of the block.
Furthermore, our protocol instructs nodes which believe they are close to the winning
vote to also produce blocks which may be selected if the true winner fails to construct
a block in a timely manner.
Bitcoin Core Team, T., 2017. Bitcoin developer reference. Available at: https://bitcoin.org/en/developer-
reference#block-headers
Crosby, M., Nachiappan, Pattanayak, P., Verma, S., et al., 2015. BlockChain technology.
Available at: http://scet.berkeley.edu/wp-content/uploads/BlockchainPaper.pdf
Nakamoto, S., 2009. Bitcoin: A peer-to-peer electronic cash system. Available at: https://bitcoin.org/bitcoin.pdf
Okupski, K., 2016. Bitcoin developer reference., pp.3–4. Available at: https://lopp.net/pdf/Bitcoin_Developer_
Reference.pdf
John Doering, 2014. NeoScrypt,a Strong Memory Intensive Key Derivation Function Available at: http://phoenixcoin.org/archive/
neoscrypt_v1.pdf