Data Transmission
    Data transmission is the movement of data (bits) between at least
       two digital devices.
      Data transmission can be over a short distance (e.g. from your
       computer to a plugged-in device) or over longer distances (e.g.
       networks).
      When data needs to be sent from one device to another, it is
       important to consider how that transmission is going to occur.
Factors to be considered and agreed between sender and
receiver:
  1. Method of transmission (how many bits are sent at the same time)
       – Serial or Parallel
  2. Direction of transmission (i.e. one direction or both) – Simplex, Half
     Duplex or Full Duplex
  3. Synchronisation method between the two devices
       – Asynchronous and Synchronous
Serial and Parallel Data Transmission
      Data transmission can occur in two modes (methods), either serial
       or parallel.
Serial data transmission
      In serial data transmission, bits are sent sequentially (one after the
       other) down the same wire (channel).
      Using a single wire reduces costs but slows down the speed of
       transmission.
      Sending data sequentially is perfect for transmitting over longer
       distances as there are no synchronisation issues.
Uses of serial transmission
  1. Transmission to another computer or to external devices
  2. Medium to long distances
  3. Universal Serial Bus (USB)
Parallel data transmission
     In parallel data transmission, multiple bits are sent simultaneously
      down different wires (channels) within the same cable.
     Data is synchronised by a clock, however this becomes problematic
      over longer distances where synchronisation errors may start to
      occur.
     Using parallel wires is more expensive but transmission is faster.
Uses of parallel transmission
     Fast transmission within a computer system
     Short distances
     Integrated Circuits (IC), Busses
Duplex, Half Duplex and Simplex
     Duplex, Half Duplex and Simplex are the three possibilities for the
      direction of data transmission.
Simplex
     Simplex is data transmission in one direction only. Two directional
      transmission is not possible.
     e.g. a radio station broadcast.
Half Duplex
     Data transmission in both directions is possible, but not at the same
      time.
     e.g. walkie talkies
Full Duplex
     Data transmission is possible in both directions at the same time
      (simultaneously).
     e.g. telephones.
Synchronous and Asynchronous
     Synchronous and Asynchronous transmission are two methods
      (protocols) of keeping data synchronised when transmitted.
Asynchronous data transmission
     Data is transmitted in discrete packets (usually 1 byte)
     Each packet of data is sent with control bits
     The control bits allow the receiver to know when the data starts and
      ends
     The control bits prevent the packets of data getting mixed up
     Packets are sent intermittently (they have uneven time intervals
      between them)
     Slower than synchronous
Synchronous data transmission
     A continuous stream of data
     The data is accompanied by timing signals (generated by an internal
      clock)
     The clock ensures the sender and receiver are in step with each
      other
     The receiver counts how many bits were sent over a period of time
      then reassembles them into bytes (multiple bytes sent at once)
     Timings have to be accurate as there are no control bits
     Faster than asynchronous
Data Packets and Packet Switching
     Before transmission, files can be broken up into smaller chunks
      called data packets.
     Each packet is very small, usually less than 64 KiB in size.
     Controlling these small data packets is easier than managing large
      continuous streams of data. This is because each data packet can
      be sent along a different route to reach its destination.
     Data packets will avoid busy or broken routes, always taking the
      route deemed fastest at any particular moment in time. The
      congestion of a particular route is constantly changing, so the
      fastest route for one data packet may suddenly be deemed the
      slowest for the next data packet.
     All of this means that data packets will arrive out of sequence and
      will need to be put back into order by the receiving computer.
The structure of a data packet
    A data packet has three sections.
  1. Packet Header:
      IP address of sending device
      IP address of receiving device
      Sequence number (e.g. packet 23 out of 100)
      Packet size
  2. Payload:
      The actual data being sent
  3. Packet Trailer:
      Mechanism to identify the end of the packet
      Error checking method (e.g. Cyclic Redundancy Check, CRC)
Packet Switching
     Packet switching is the process of transmitting data by splitting it
      into a series of small data packets (as described above).
     A data packet will encounter several nodes as it makes its journey
      from A to B.
     At each node is a router. The router will process the data packets,
      using the information found in the head section of the packet.
     A router will independently send each packet onto the next leg of its
      journey, using the most appropriate route at that exact moment in
      time.
Pros and Cons of packet switching
   High transmission rates can be achieved through packet switching
   No single connection is fully occupying a communication line
   Busy or faulty lines will not stop data from reaching its destination
   Expansion is easy to achieve
   Lost packets will need to be resent
   Putting packets back into the correct sequence causes a small delay
Universal Serial Bus (USB)
    Universal Serial Bus (USB) is a type of cable and connector
     commonly used for half-duplex or full-duplex serial data
     transmission between a computer and attached devices.
   A USB cable consists of a shielded casing containing four wires. Two
     wires are used for power and earth, and the other two wires are
     used for data transmission.
   Typical cables can reach up to 5 metres.
There are many benefits to using USB cables:
  1. USB is widely used and available on most computers and connected
     devices. When buying a new device, we just assume that it will
     connect via USB, safely knowing that our computer will have the
     appropriate ports to make that connection
  2. Devices connected by USB are automatically detected by the
     computer (and device drivers loaded if available)
  3. USB cables can’t be connected incorrectly (unless you apply some
     serious force!)
  4. Various different transmission speeds are supported, ranging from
     the slow and dated USB 1.0 (1.5 Mbps) through to the very fast
     present-day USB 4 (40 Gbps)
  5. No need for an external power supply for your small device. USB
     cables carry power and data
  6. Hubs allow additional ports to be created
  7. USB is backward compatible. However, you will only benefit from
     the faster speeds if both devices support it
USB-C connectors are growing in adoption. These are beneficial
because:
   They provide USB data transmission, but usually at the higher rates
    (10 Gbps+)
   Can be connected both ways up (there is no correct orientation)
   USB-C can carry much more power, allowing larger devices to be
    powered without external power sources
     They are generally more robust
Error Detection
     There is always the chance that data has been corrupted (changed
      in some way) during transmission.
     This is true regardless of the distance of transmission.
     To avoid having corrupted data it is really important that
      computers check for errors and correct them wherever possible.
     There are several methods of error checking, with some being more
      effective than others.
  1. Parity Check
      An extra bit (parity bit) added to a string of binary code to ensure
       the number of 1-bits are either even or odd, depending upon
        the parity check system used.
      Method
        1. The sending and receiving computers agree the protocol to be
           used (even or odd)
        2. The sending computer adds the correct parity bit to the binary
           data (either an extra 1 or 0)
        3. The sending computer sends the binary data, including the
           parity bit
        4. The receiving computer checks to make sure the overall parity
           of the data received is as agreed (an even or odd number of 1
           bits)
        5. If the parity of the data is incorrect, the receiving computer
           will request that the data is transmitted again
      Drawbacks of parity checks
         If two bits are transposed (change places) then the computer
           could be fooled into thinking the data is correct and not
           corrupted
         If two random bits change state then the system could also be
           fooled
2. Parity Block
    This method of error checking is similar to a traditional parity
     check except the data is arranged in a virtual table with parity
     bits added to each row and column.
    A single corrupted bit can be spotted at the intersection of
     a corrupted row and column.
    Multiple corrupted bits would also flaw this system.
3. Checksum
    A block of data is sent alongside a calculated checksum value.
    The receiving computer also calculates what it believes should be
     the checksum.
    The checksum values are then compared to see if an error has
     occurred during transmission.
   Method
      1. The sending computer uses the block of data to be sent, and a
         predefined mathematical algorithm, to calculate a checksum
         value
      2. The sending computer sends the data, plus the checksum
         value
      3. The receiving computer uses the data it receives to also
         calculate what it believes should be the checksum, using the
         same mathematical algorithm
      4. The two checksum values are compared by the receiving
         computer
      5. Due to the nature of the algorithm, it is highly unlikely that
         corruption has occurred if the checksum values match
      6. If the checksum values don’t match, the receiving computer
         requests that the data is transmitted again
4. Check Digit
    A check digit is the final digit in a code of numbers. It is
     calculated from all the other digits in the code. Its purpose is to
     spot human errors on data entry.
    Check digits are often found in barcodes, product codes or ISBN
     book numbers.
         There are many different mathematical algorithms that can be
          used to calculate a check digit. Different industries will have
          their own preferred method.
      Method
        1. The check digit is calculated and added to the barcode,
           packaging, product code etc at the point of manufacture
        2. A human type the long numerical code into a computer, e.g.
           the cashier will type the barcode number when a scanner fails
           or packaging is damaged
        3. The computer calculates what it believes should be the check
           digit, based on the numbers entered by the human
        4. The computer then compares it’s calculated check digit with
           the check digit typed in by the human (the last digit in the
             long code)
          5. If the two don’t match, then the human has made an error
             when typing in the numerical code, e.g. barcode number
          6. The human will be asked by the computer to re-enter the
             numerical code
      Benefits
      Good for spotting human errors such as:
         Incorrect digit entered
         Transposition error (two numbers change order)
         Omitted digit or extra digit
Automatic Repeat ReQuests (ARQ)
     This form of error detection uses a system
      of acknowledgements and timeouts. Automatic Repeat
      ReQuests are often used to ensure reliable transmissions over an
      unreliable service.
     Acknowledgements are messages sent from a receiving device back
      to the original sending device.
     The acknowledgement can be negative or positive.
     A positive acknowledgement means that the data was received and
      it passed an error check.
     A negative acknowledgement means that the data was received but
      it cannot be used as it failed an error check. It needs to be sent
      again.
     The timeout is a predetermined period of time that the sending
      device will wait to get some form of acknowledgement for the data
      it sent.
     If no acknowledgement is received after the timeout, the device will
      sent the data again. This continues automatically until an
      acknowledgement is received, or the maximum number of re-sends
      occur.
Method
  1. The sending computer transmits a block of data
  2. The sending computer waits a period of time to see if the receiving
     computer acknowledges receipt of the data
  3. After no acknowledgement for a set period of time, a timeout occurs
     which triggers the data to be automatically resent by the sending
     computer
  4. This will continue until the receiving computer acknowledges the
     data has been received, or a max number of re-sends occurs
Echo Check
With an echo check, the receiving computer sends a copy of the data
immediately back to the sending computer for comparison.
The sending computer compares the two sets of data to check if any
errors occurred during the transmission process.
If an error has occurred, the data will be transmitted again.
Drawback of echo checks
      If the two sets of data are different you will have no way of knowing
       whether the error occurred when originally sent, or when it was sent
       back
      Echo checks require a lot of extra data to be transmitted
Computer Network
Connecting stand-alone computers together creates a computer network.
Networks can be wired, wireless, or a combination of both.
Advantages of computer networks
      Share data with other users
      Access your data from other computers
      File servers can store data in a central location, making it easier to
       keep secure and backup
      Application servers can be used to store software in a central
       location
      Communications can be sent from one computer to another
      Printers can be shared
      An internet connection can be shared
Disadvantages of computer networks
     Larger networks can be expensive to setup and staff
     Networks can have security risks
     Viruses can be spread if not properly protected
     Depending on the network structure, the entire network could fail if
      certain elements fail
     High amounts of traffic can cause a network to run slowly
PANs, LANs and WANs
Networks are often classified as PANs, LANs or WANs.
Personal Area Network (PAN)
     A computer network of devices within close distance of an individual
      and their work space
     Examples include interconnecting an individual’s computer,
      smartphone and tablet (wired e.g. by USB, or wireless e.g. by
      Bluetooth)
Local Area Network (LAN)
     A computer network that covers a small geographical area
     Examples include schools, small businesses, homes
Wide Area Network (WAN)
     A computer network that covers a large geographical area
     Examples include banks, hospitals, police forces, the Internet
Several LANs can be connected together to create a WAN.
Peer-to-Peer Networks
Peer-to-peer networks are computer networks that do not have a
central server controlling the network.
Each computer is called a peer, and these peers are connected to one
another.
No computer has control over another.
This type of network is not suitable for a large network where a client-
server structure would be preferable.
Benefits of a peer-to-peer network
      Each computer can communicate and share its data and resources
       with all others (e.g. files or even a printer)
      Users can control which files they wish to share or keep private
      No cost in buying a server
      No need to pay a network technician (each user manages own file
       sharing permissions)
      Easier to set up with less specialist knowledge needed
      Over-all set up cost is cheaper
      Computer failure will only disrupt the files being shared from that
       computer (unlike a server failure on a client-server network)
Drawbacks of a peer-to-peer network
      Difficult to recover files as they are not backed up centrally
      Each computer needs its own backup system
      Files and resources are more difficult to share
      Files are potentially less secure when not centralised
      Difficult to administrate the whole network as the system is not
       centralised
      Performance may be slower due to each computer fulfilling more
       than one role and being accessed by others
      Security can be more expensive as each computer needs its own
       anti-virus software
      It is up to the user of each computer to ensure viruses are not
       introduced to the network
      Having lots of users/computers on the network becomes
       problematic
Client-Server Networks
Client-server networks are computer networks that use a dedicated
computer (server) to store data, manage/provide resources and control
user access.
The server acts as a central point on the network upon which the other
computers connect to.
A computer that connects to the server is called a client.
A client-server network is usually preferred over a peer-to-peer network
that doesn’t have a central server to manage the network.
Network server functions
A client-server network may have more than one server, each dedicated
to handling a specific function.
Functions may include:
      Data storage
      Handling security
      Hosting shared applications
      Managing an internet connection
      Scheduling and running backups
      Email services
      Print jobs
      Domain name services
      Storing usernames and passwords to control access
      Assigning levels of access to resources
      Monitoring network traffic
Benefits of a client-server network
      Generally more secure than peer-to-peer networks
      One client computer crashing does not effect the other computers
      Easier to recover files as backups can be controlled centrally by the
       network administrator
      Files and resources are easier to share and control from server
      Improved levels of security as files are centralised
      It’s easier to administrate the whole network using a server
      Faster performance as each computer is only fulfilling one role
      Security is potentially cheaper and easier when done centrally
      Individual users do not have to worry about backups or security
      Larger networks can be created
Drawbacks of a client-server network
      Servers can be expensive to buy and maintain
      A network technician will often be required
      Trickier to set up with specialist knowledge needed
      Over-all set up cost is more expensive than a peer-to-peer network
      Server failure will probably disrupt all computers on the network
Virtual Private Network (VPN)
A virtual private network (VPN) is used to securely access a private
network (usually a LAN) from a remote location.
VPNs make use of potentially unsafe external (public) communication
systems such as the internet.
Once connected to a VPN, the remote computer has secure access to the
private network, just as if it was directly connected to the LAN.
Data remains encrypted throughout the entire transmission (this is called
tunnelling).
VPN security consists of firewalls, encryption and IP security (IPsec).
Uses of VPNs
      Network access for travelling employees
      Network access for teleworking employees
      Allows staff to access a work network whilst at home
      Allows LANs within an organisation to connect to each other
      Individual use for private internet browsing
Advantages of VPNs
      High level of security of data transmitted over the internet
      More secure than other remote communication methods
      Every file is encrypted – so no unauthorised reading of files
      Cheaper than creating a conventional WAN (no leasing of expensive
       dedicated telecommunication lines)
      Adding more client’s costs very little
      Can be configured to work automatically when logging on to a
       computer
      External resources are maintained by someone else
      Enables organisations to communicate over a large area
Drawbacks of VPNs
      Performance may be outside of the control of the organisation
      Performance depends on the ISP and so can be variable
      Packet loss can be higher over a VPN, leading to re-transmission,
       increasing the time taken to receive documents
      Some users may have restrictions put on their computers to protect
       the integrity of the VPN connection (e.g. no third-party software,
       compulsory anti-malware tools)
     Technical expertise is required to set up and maintain
Error-Checking Methods
Parity check
         Checks a byte of data
         Check is performed when data is received
         A parity bit is added (to the parity byte)
         Counts / checks number of 1’s // counts / checks to see if 1’s are
          even // counts / checks to see if 1’s are odd
         Can be even or odd. If parity is incorrect, error is detected
The situations which parity check may not identify that a bit has
been transmitted incorrectly
         2 bits interchanged (e.g. 1 –> 0 and 0 –> 1) that won’t change parity
          value
         even number of bits/digits are transposed
         If there are multiple errors in the same byte/column, that still produce
          the same parity bit, the error will not be detected
Check sum
         sum of bits is transmitted and checked against the sum of the received
          bits
Check digit
         A value is calculated from the data // Valid description of calculation
         It is transmitted with the data
         Value is recalculated after transmission
         Values are compared after transmission to check for error
ARQ (Automatic Repeat request)
         Error control protocol
         when an error is detected in a packet of data a request is
          automatically sent for the data to be resent
         Uses acknowledgement / request and time-out
         Check performed on receiving data // error is detected by
          e.g. parity check, check sum
        If error detected, request is sent to resend data //
         negative acknowledgement is used
        Resend request is repeated till data is sent correctly /
         requests time out / limit is reached
        Send acknowledgement that data is received // positive
         acknowledgement is used
        If acknowledgement not received in set time data is
         resent
Echo Check
Data is sent to another device, this data is sent back to the ender.
The sender compare the two sets of data to check if any errors
occurred during the transmission process.