Intermediate commit
This commit is contained in:
parent
7735ebd5f4
commit
492615343f
197
dd.latex
197
dd.latex
@ -27,73 +27,146 @@
|
||||
|
||||
\pagebreak
|
||||
|
||||
\section{Introduction}
|
||||
The Fenceless Grazing Collar project is primarily divided into three parts: the hardware
|
||||
in the field (the physical collars placed onto animals), the communication protocol
|
||||
and software linking the collars to other devices used to control the settings
|
||||
of the collars, and the smart application which used to configure the collars
|
||||
through a user-friendly interface.
|
||||
|
||||
\section{Hardware}
|
||||
To separate responsibilities between program logic and driver logic driver software will be developed for AVR to drive the hardware devices, this software is also known as a driver. In software the driver is a program or set of instructions that control some piece of hardware. In our project this driver is to be used by the logic code of the program to control any hardware connected to our collar. Drivers will be written for the collars to allow for control of devices such as: the LoRa transceiver, buzzer, haptic feedback, shocker, and GPS. As the LoRa device is the most complex to drive, more general driver code will be written that will be used by the main program than what is to be written for the other peripherals. The buzzer, haptic, shocker, and GPS drivers will provide a higher level interface for driving these peripherals that is more complete in its control of the devices. All libraries are to be written in pure AVR C to maximize learning and control.
|
||||
|
||||
For debugging of the AVR parts of the project, serial debug libraries will be implemented to allow observation of the system from a connected computer. The debugging library will be written in pure AVR C and coded to work specifically with our chosen micro-controller. This debugging library will need to be implemented asynchronously to prevent stalling of other hardware drivers to the connected peripherals. Having an asynchronous debugging library provides an extra method to debug the I2C and SPI protocols both in real-world test and simulated tests.
|
||||
|
||||
To test the embedded firmware of the project, AVR simulation will be used. Simulation will allow for the basic debugging of signals without the need for an oscilloscope or other logic analyzer. While the simulation will not always reflect real-world conditions, it will illustrate general operation of the collar in ideal conditions. The program used to simulate will be simavr, this being a program that supports most-all AVR micro-controllers. This program allows for the output of digital signals such as: pins, registers, SPI, and I2C. Signals output by simavr are easily viewable in the program GtkWave which is an open source alternative to Modelsim.
|
||||
|
||||
All devices in the project need to be portable or semi-portable. There are two types of devices in the system. The collar which is to be put on an animal and needs to be purely portable. The gateway which should be able to fit in a backpack and be semi-portable. The collar will use a 14500 Lipo which is used in many AVR development boards with LoRa. The gateway is a
|
||||
Raspberry Pi and will be easily powered through a USB power bank unless a more robust solution is required.
|
||||
|
||||
\section{LoRa}
|
||||
Communication over vast distances will be solved via the LoRa (Long Range) technology patented by Semtech. In order to fully implement the LoRa protocol patented transmitters and receivers are required. The first step in this process is to purchase and integrate the LoRa transmitters and receivers to each end node and the gateway. Actual integration with the LoRa receivers to our backend logic and server will likely be the most complicated part, and as a result is expected to take until spring quarter at the very latest to fully implement. Depending on time constraints, boards with LoRa transmitters and receivers already attached may be purchased. Drivers will need to be written and integrated into our software stack before testing can begin. Setting up the communication between these devices, ensuring scalability, and providing a reliable service are necessary for this project. Hardware will need to be sourced, integrated, and tested on each collar. The number of gateways will need to be determined on a case-by-case basis for each farm. A study will need to be conducted into the optimal way to setup a LoRa network, with distance and battery life taken into consideration. Once the number of communications per day are determined, the distance required, and the battery life needed the number of gateways can be determined. Each farm will have different requirements (number of animals, distance between end nodes and gateways, etc.) and in order to determine limitations in terms of these variables data will need to be gathered with an actual LoRa network. Once the LoRa proprietary chips are purchased and integrated into the end nodes and gateway data collection and testing will begin. Our primary goal upon receiving hardware is ensuring that everything works as intended, including building a software backend to support transmitting and receiving information between nodes. In order to ensure correct functionality and implementation of the LoRaWAN protocol extensive time will be spent testing our hardware. Once we have successfully communicated between two LoRa chips via the chirp spread spectrum (CSS) technology data will be gathered in terms of distance of communication over different types of land. For example, we need to categorize our hardware and give a maximum distance over flat land, through buildings, and other terrain. The next step in terms of data collection of the capabilities of the LoRa network will be to determine how frequently we need each end-node to communicate to the server, and how many end nodes are required per farm. With this information the number of gateways can be determined based on the frequency of packet collisions in the network. This may need to be tested with the actual hardware to provide accuracy, which can only be accomplished once the actual hardware is set in stone due to the necessity of gathering multiple devices. This may not be necessary for our project, and possibly can remain at theoretical stage based on any time constraints we encounter. For example, the theoretical collision rate between end nodes transmitting at a certain frequency can be determined which will provide good estimates for the required hardware for each network. Overall, communication between two LoRa transmitters/receivers needs to be completed by at least week 5 in the winter term in order to move onto driver development and LoRa capability testing.
|
||||
|
||||
\section{Smart Application}
|
||||
One of the requirements for the project is the development of a smart application which
|
||||
serves to control the collar devices in the field. This application will be developed
|
||||
using the Kotlin programming language for the Android platform, with the aim to
|
||||
support 95\% of the devices currently available on the platform (the analysis of the
|
||||
requried Android version to fulfil this requirement will be performed when
|
||||
the application begins development). The application will use a JSON HTTP API
|
||||
to interact with an external device, the LoRa gateway and data server. This
|
||||
means that the applications themselves will not store any data about the collars
|
||||
except for caching, and will rely entirely on the LoRa gateway to interact
|
||||
with the collars in the field.
|
||||
This section outlines the design of the smart application, used for manipulating
|
||||
deployed collars from a user device.
|
||||
|
||||
The LoRa gateway will be a Raspberry Pi Linux machine, configured to store data
|
||||
gathered from the fenceless collars, as well as to forward communication from the
|
||||
Android devices to the collars placed onto animals. To do so, the Raspberry Pi
|
||||
will provide a JSON HTTP API, exposed to the open internet and protected through
|
||||
authentication based on the JSON Web Token (JWT) technology. The server,
|
||||
written in Python, will receive authentication requests from the Android
|
||||
applications (or other client applications), and generate JSON tokens signed
|
||||
with a secret key. These JSON tokens will be returned to the applications
|
||||
to indicate a completed authentication, and then used to authorize further
|
||||
requests to the machine.
|
||||
\subsection{Application Platform}
|
||||
The smart application will be a smartphone program based on the Android mobile operating
|
||||
system. This allows the application to be installed on the majority of phones
|
||||
currently in use in the United States [citation needed], and minimizes the complexity
|
||||
of developing the project. The application will be written in the Kotlin language,
|
||||
which is designed as a replacement for Java. Because Koltin is one of the official languages
|
||||
for the Android platform, it will be used with the standard libraries and frameworks
|
||||
provided by the platform. The usage of Kotlin and standard libraries will not only
|
||||
improve code quality (due to various features of the Koltin language such as
|
||||
compile-time null safety and automatic code synthesis), but will also improve
|
||||
user experience by avoiding additional layers of abstraction between the
|
||||
application and the user.
|
||||
|
||||
The LoRa gateway will interact with LoRa-equipped collars in the field through
|
||||
the use of a Raspberry Pi-compatible LoRa shield (a hardware component that
|
||||
can be added to the Raspberry Pi without soldering or other "intensive" hardware
|
||||
work).
|
||||
\subsection{Communication with Other Components}
|
||||
Because the application is intended as a means of controlling Fenceless Grazing Collars
|
||||
in the field, there must exist a way for communicating information between the application
|
||||
and the collars themselves. Direct communication with individual collars is not possible due
|
||||
to the lack of a LoRa receiver on the typical Android device. To work around this, the application
|
||||
will communicate with the LoRa gateway, a device equipped with a LoRa transmitter and
|
||||
receiver. The Android application will perform requests
|
||||
to the LoRa gateway via an HTTP API, and display the result of the interaction to
|
||||
the user. For details on the HTTP API, see the corresponding section.
|
||||
|
||||
The LoRa gateway will be configured with a MySQL database storing the recent
|
||||
GPS data for each animal in the field. Location data will be stored in 15 second intervals,
|
||||
to prevent excessive pollution of the database with redundant information, and to
|
||||
reduce the storage requirement of the LoRa gateway. Additionally, each time that
|
||||
a stimulus is used by a collar to prevent an animal from leaving the desired
|
||||
area, this event will also be logged by the collar, to provide farmers with
|
||||
potentially critical information about the behavior of the animals. In order
|
||||
to properly tell apart the various animals, the unique identifier of each
|
||||
collar will also be stored in the database along with every location and
|
||||
stimulus entry. When a client (such as an Android application as described above)
|
||||
requests a specific piece of information, the server on the Raspberry Pi will
|
||||
perform an SQL query matching the type of the request, and convert the resulting
|
||||
data into the JSON format expected by the API. This way, the server-side implementation
|
||||
of data storage does not affect the client code, and future changes (such as
|
||||
switching to a different SQL database, or to a NoSQL storage system) will
|
||||
be easier to integrate.
|
||||
\section{Application Server}
|
||||
This section describes the software running on the LoRa gateway that is
|
||||
responsible for handling API requests from the Smart Application.
|
||||
|
||||
\section{Conclusion}
|
||||
Over the course of the next six months our team will develop and build the hardware and software required for our project including the physical collars on the animals, the communication protocol LoRa and LoRaWAN, and the software linking the collars to the Android application. Drivers will be written and integrated on each collar to connect all of the components into one central interface system complete with a logic program sending and receiving data from the server. This communication will be provided via the LoRa communication protocol, providing a long distance low bandwidth interface. Extensive testing will be conducted into the efficiency and scalability of the LoRa system to ensure proper implementation across all varieties of farms and farmland. Lastly, an Android application and HTTP server will be written to allow user interaction with all collars across the farm. These applications will be complete with an SQL database and API allowing for simple communication between the phone and server. Data about each animal, their location, and other information will be stored in the server and readily available to the user. All of these components will come together to provide a complete, working prototype to simplify the work required by farmers and decrease overall interaction with their livestock.
|
||||
\subsection{Language and Platform}
|
||||
The LoRa gateway is a Raspberry Pi equipped with
|
||||
a hardware shield to allow for LoRa-based communication. The Raspberry Pi
|
||||
platform has official support for using the Python programming language to
|
||||
interface with external components like the shield[citation needed], and thus Python
|
||||
will be used to implement the software for both the Application-Server
|
||||
interaction, and for the Gateway-Collar communication.
|
||||
|
||||
\subsection{Data Storage}
|
||||
The Application Server will store and retreive data into a MariaDB SQL database
|
||||
configured on the same device as the server software. The following data will be
|
||||
logged every 15 (fifteen) seconds, for each collar:
|
||||
\begin{itemize}
|
||||
\item The identifier of the collar
|
||||
\item The GPS coordinates
|
||||
\item The battery level
|
||||
\item Whether the GPS coordinates are currently outside of expected bounds.
|
||||
\end{itemize}
|
||||
|
||||
Furthermore, each time that an auditory or electrical stimulus is used, the
|
||||
following information will be logged:
|
||||
\begin{itemize}
|
||||
\item The identifier of the collar
|
||||
\item The GPS coordinates
|
||||
\item The "severity" of the stimulus
|
||||
\end{itemize}
|
||||
|
||||
Here, the severity of stimulus refers to the notion of progressively
|
||||
increasing stimuli: if an animal does not respond to a sound of a particular
|
||||
volume, the next attempt will increase the volume to a higher level, or
|
||||
invoke electric shocks.
|
||||
|
||||
\subsection{Frameworks and Libraries}
|
||||
The Python application will use the SQLAlchemy Object Relational Model (ORM)
|
||||
library to simplify access to the database. This library provides an
|
||||
object-oriented approach of manipulating data stored in a relational database.
|
||||
This approach is useful for the server due to Python's preference for the
|
||||
object-oriented model.
|
||||
|
||||
The Flask web application framework will be used to provide the HTTP API.
|
||||
The framework introduces minimal additional complexity, but provides
|
||||
all the necessary features to implement the HTTP API as specified in
|
||||
the corresponding section.
|
||||
|
||||
\section{HTTP API}
|
||||
This section describes the HTTP API that is used in the interaction
|
||||
of the Application Server and the Smart Application. The API
|
||||
specifies a "server" and a "client". The "server" is the
|
||||
software running on the LoRa gateway, having access to the database
|
||||
and able to communicate with collars in the field. The "client"
|
||||
is any party wishing to use the HTTP API to trigger an action
|
||||
or retreive information from the grazing collars. At present,
|
||||
this is simply the Smart Application.
|
||||
|
||||
\subsection{Authentication}
|
||||
Authentication will be achieved through the use of JSON Web Token
|
||||
(JWT) technology. The procedure for verifying a client's identity
|
||||
is as follows:
|
||||
|
||||
% TODO ol instead of ul
|
||||
\begin{itemize}
|
||||
\item Receive JSON object containing username and password from the client.
|
||||
\item Compute password hash using BCrypt, and search database for matching credentials.
|
||||
\item If found, create JWT token containing the unique identifier of the user.
|
||||
\item Return JWT token to client in the HTTP response.
|
||||
\end{itemize}
|
||||
|
||||
The client is expected to then provide the generated JWT token when making further
|
||||
API requests.
|
||||
|
||||
\subsection{Encoding}
|
||||
The API will use JSON for requests and responses. On the client side, simple data, such as the JWT authentication
|
||||
token, will be encoded in the URL of the API request, while complex data, such as coordinates,
|
||||
will be encoded in JSON.
|
||||
|
||||
\subsection{API}
|
||||
The API provides the following methods:
|
||||
|
||||
\begin{itemize}
|
||||
\item \textbf{/auth/login}
|
||||
\begin{itemize}
|
||||
\item \emph{URL Parameters:} none
|
||||
\item \emph{Parameters:} username and password of the account that is being logged into.
|
||||
\item \emph{Result:} JWT for use in further API requests.
|
||||
\end{itemize}
|
||||
\item \textbf{/auth/<token>/logout}
|
||||
\begin{itemize}
|
||||
\item \emph{URL Parameters:} none
|
||||
\item \emph{Parameters:} none
|
||||
\item \emph{Result:} JWT token is no longer valid for future requests.
|
||||
\end{itemize}
|
||||
\item \textbf{/data/<token>/current}
|
||||
\begin{itemize}
|
||||
\item \emph{URL Parameters:} none
|
||||
\item \emph{Parameters:} none
|
||||
\item \emph{Result:} list of coordinates, battery levels, and "in-bounds" tags for each active collar.
|
||||
\end{itemize}
|
||||
\item \textbf{/data/<token>/collar/<id>}
|
||||
\begin{itemize}
|
||||
\item \emph{URL Parameters:} identifier of collar.
|
||||
\item \emph{Parameters:} none
|
||||
\item \emph{Result:} list of data points for the collar with the given identifier.
|
||||
\end{itemize}
|
||||
\item \textbf{/adjust/<token>}
|
||||
\begin{itemize}
|
||||
\item \emph{URL Parameters:} none
|
||||
\item \emph{Parameters:} list of coordinates specifying the vertices of new boundary area.
|
||||
\item \emph{Result:} LoRa command to adjust boundary is issued.
|
||||
\end{itemize}
|
||||
\end{itemize}
|
||||
|
||||
\end{document}
|
||||
|
Loading…
Reference in New Issue
Block a user