Line 1: | Line 1: | ||
+ | {{:Team:NTHU_Taiwan/MenuBar}} | ||
<html> | <html> | ||
Line 10: | Line 11: | ||
#bodyContent {background-color:#f6f6e3;} | #bodyContent {background-color:#f6f6e3;} | ||
#bodyContent h1, #bodyContent h2, #bodyContent h3, #bodyContent h4, #bodyContent h5 { margin-bottom: 0px; } | #bodyContent h1, #bodyContent h2, #bodyContent h3, #bodyContent h4, #bodyContent h5 { margin-bottom: 0px; } | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
Line 136: | Line 39: | ||
.igem_2017_content_wrapper h1, .igem_2017_content_wrapper h2 .igem_2017_content_wrapper h3, .igem_2017_content_wrapper h4, .igem_2017_content_wrapper h5, .igem_2017_content_wrapper h6 { | .igem_2017_content_wrapper h1, .igem_2017_content_wrapper h2 .igem_2017_content_wrapper h3, .igem_2017_content_wrapper h4, .igem_2017_content_wrapper h5, .igem_2017_content_wrapper h6 { | ||
− | padding: | + | padding: 50px 0px 15px 0px; |
border-bottom: 0px; | border-bottom: 0px; | ||
color: #2C2C2C; | color: #2C2C2C; | ||
Line 143: | Line 46: | ||
} | } | ||
− | + | .igem_2017_content_wrapper .content { | |
width: 950px; | width: 950px; | ||
− | |||
margin: 2em auto; | margin: 2em auto; | ||
− | |||
} | } | ||
− | # | + | .igem_2017_content_wrapper .content p{ |
+ | color: #2C2C2C; | ||
+ | font-size: 1.4em; | ||
+ | line-height: 1.3em; | ||
+ | padding: 0px 0px; | ||
+ | } | ||
+ | |||
+ | .igem_2017_content_wrapper .content img{ | ||
+ | margin: auto; | ||
display: block; | display: block; | ||
− | + | float: center; | |
+ | padding: 20px 0px 30px 0px; | ||
} | } | ||
− | + | .column .full_size { | |
+ | width: 100%; | ||
+ | padding-top: 50px; | ||
+ | } | ||
− | /* | + | /* class for a half width column */ |
− | + | .column .half_size { | |
+ | width: 50%; | ||
+ | float: left; | ||
+ | } | ||
− | + | #pdf { | |
− | + | width: 950px; | |
− | + | height: 1200px; | |
− | + | margin: 2em auto; | |
− | + | padding-top: 20px; | |
− | + | ||
− | + | ||
} | } | ||
− | + | #pdf object { | |
− | + | display: block; | |
− | + | border: solid 2px #2c2c2c; | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | # | + | |
− | + | ||
− | + | ||
− | + | ||
} | } | ||
− | |||
</style> | </style> | ||
Line 194: | Line 97: | ||
</head> | </head> | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
Line 397: | Line 102: | ||
<!-- start of content --> | <!-- start of content --> | ||
<div class="igem_2017_content_wrapper"> | <div class="igem_2017_content_wrapper"> | ||
− | |||
<div style="text-align: center"> | <div style="text-align: center"> | ||
<h1 style="color:#DF6A6A">Software | <h1 style="color:#DF6A6A">Software | ||
Line 404: | Line 108: | ||
<hr width="20%" /> | <hr width="20%" /> | ||
</div> | </div> | ||
+ | <div class="content"> | ||
+ | <h1 style="color: #6c5070">Software Design: IoT System and App</h1> | ||
− | < | + | <p> |
− | + | With the implementation of our device, we now can provide farmers a water protection system. Furthermore, we have developed an app and IoT system. The app will allow the user to know the condition of the farmland water, and the IoT system is set to save all the data and collaborate with other nearby protection systems to build up a “safe web.” When our devices are widely spread around a region, we would not only be able to help the farmers keep their farmland’ water source safe, but even identify when and where the pollution came from. | |
− | + | </p> | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | </ | + | |
− | + | ||
− | + | ||
+ | <h2> | ||
+ | The IoT System | ||
+ | </h2> | ||
+ | <h2> | ||
+ | Why IoT? | ||
+ | </h2> | ||
+ | <p> | ||
+ | In order to fulfill the purpose of data monitoring in real-time, we have to implement IoT system to our device. The implementation can be simply classified in the following steps: | ||
+ | </p> | ||
− | < | + | <p> |
− | + | 1. Sensors (temperature, PH detector) collect data to our controller. | |
− | </ | + | </p> |
+ | <p> | ||
+ | 2. Controller upload data to cloud through wifi. | ||
+ | </p> | ||
− | < | + | <h2> |
− | + | What have been used? | |
− | </ | + | </h2> |
− | < | + | <h2> |
− | + | Cloud Platform : MediaTek Cloud Sandbox | |
− | + | </h2> | |
− | + | ||
− | + | ||
− | </ | + | |
− | + | ||
− | + | ||
− | + | ||
+ | <p> | ||
+ | We created an account on MediaTek Cloud Sandbox, therefore, our data will be going there. | ||
+ | </p> | ||
− | <p> | + | <p> |
− | + | After establishing an MCS account, we start to create our virtual device and data channel. When data channel is being created, they will have their own Device ID and Device Key. So, when writing our Arduino code and assign them with specific Device ID and Device Key, our data will be able to send to that data channel. | |
− | + | </p> | |
− | + | ||
− | </p | + | |
− | < | + | <h2> |
− | + | Controller and Sensors | |
− | </ | + | </h2> |
− | <p> | + | <p> |
− | + | The controller is the heart of our device, where it is responsible for receiving, processing, uploading data to the cloud, and also control our motor. | |
− | </p | + | </p> |
− | |||
− | |||
− | |||
− | <p> | + | <p> |
− | + | The reason why we choose MediaTek LinkIt™ ONE as our controller mainly because it has its own cloud platform MediaTek Cloud Sandbox, which enable us to implement IoT system to our device much easier. As for the sensors, right now we have used a thermometer and pH meter. Fluorescence detector will be added to the system once biochip has been successfully manufactured. | |
− | + | </p> | |
− | + | ||
− | </p | + | |
− | < | + | <h2> |
− | + | How we do this? | |
− | + | </h2> | |
− | </ | + | |
− | + | ||
− | < | + | <h2> |
− | + | Step 1: Sensors collect data to our controller | |
− | </ | + | </h2> |
− | <p> | + | <p> |
− | + | This part is relatively simple, based on the sensors we use, we search for the corresponding code on the Internet, and copy them into our Arduino code (Figure 1). Once we have the code and correct PIN connected to our sensors, then we are good to go. | |
− | </p | + | </p> |
− | |||
− | |||
− | |||
− | |||
− | |||
− | <p>< | + | <p> |
− | + | <img width="50%" src="https://static.igem.org/mediawiki/2017/6/60/T--NTHU_Taiwan--Applied_Design--IoT_step1_code.png"> | |
− | + | </p> | |
+ | <p><center><font size="2"> | ||
+ | Figure 1 | ||
+ | </font></center></p> | ||
− | |||
− | |||
− | |||
− | < | + | <h2> |
− | + | Step 2: Controller upload data to cloud through wifi | |
− | + | </h2> | |
− | </ | + | |
− | + | ||
− | <p | + | <p> |
− | + | Remember the Device ID and Device Key that we mentioned before? In this part, we are going to use it. The function of them works like the address, when we assign specific Device ID and Device Key inside our code (Figure 2), our data can be correctly sent to the corresponding data channel. | |
− | + | </p> | |
− | + | ||
− | + | ||
− | <p>< | + | <p> |
− | + | <img width="50%" src="https://static.igem.org/mediawiki/2017/1/1a/T--NTHU_Taiwan--Applied_design--IoT_step2_code.png"> | |
− | + | </p> | |
− | <p> | + | <p><center><font size="2"> |
− | < | + | Figure 2 |
− | </p | + | </font></center></p> |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
+ | <video width="960" height="720" controls> | ||
+ | <source src="https://static.igem.org/mediawiki/2017/3/33/T--NTHU_Taiwan--test.mp4" type="video/mp4"> | ||
+ | </video> | ||
− | <p><font size= | + | <p><center><font size="2"> |
− | + | IoT Demo Video | |
− | + | </font></center></p> | |
− | </ | + | |
− | </ | + | |
− | |||
− | |||
− | |||
− | < | + | <h2> |
− | + | The App Design | |
− | </ | + | </h2> |
+ | <h2> | ||
+ | Why we built this APP? | ||
+ | </h2> | ||
− | <p> | + | <p> |
− | + | The purpose of building this APP is that we hope to monitor values from our detection point in real-time.Furthermore, if we have multiple detection points in the future, we can label all data with different colors of markers according to their concentrations, and show them on the google map. Therefore, we can get regional concentrations at once, which enable us to identify sources of pollution with ease. | |
− | + | </p> | |
− | + | ||
− | + | ||
− | + | ||
− | </p | + | |
+ | <h2> | ||
+ | How do we build our APP? | ||
+ | </h2> | ||
− | < | + | <p> |
− | + | The software we use is Android Studio. And we manage to represent our detection data in the following ways: | |
− | </ | + | </p> |
− | <p> | + | <p> |
− | + | Tab1: Real-time detection value from a single detection point. | |
− | + | </p> | |
− | + | ||
− | + | ||
− | + | ||
− | </p | + | |
+ | <p> | ||
+ | Tab2: Historical monitoring data from a single detection point. | ||
+ | </p> | ||
− | <p | + | <p> |
− | + | Tab3: The distribution of all detection points and their visualized EDC concentrations. | |
− | + | </p> | |
− | The | + | |
− | + | ||
− | + | ||
− | </p | + | |
− | <p | + | <p> |
− | + | Since our detection system has implemented Internet of Things (IoT), therefore, all data being detected will be stored to our cloud in JSON format (For details, please refer to DEVICE / Software – IoT page). So if we want to retrieve those data from our cloud, what we have to do can be simplified as followings: | |
− | + | </p> | |
− | + | ||
− | + | ||
− | <p | + | <p> |
− | + | 1. Get JSON file from server. | |
− | + | </p> | |
− | <p | + | <p> |
− | + | 2. Parse JSON to retrieve specific data. | |
− | + | </p> | |
− | + | ||
− | + | ||
− | <p | + | <p> |
− | + | 3. Display. | |
− | + | </p> | |
− | <p | + | <p> |
− | + | Now we will go through those steps one by one : | |
− | + | </p> | |
− | <p | + | <p> |
− | + | 1. Get JSON file from server | |
− | + | </p> | |
− | <p | + | <p> |
− | + | Data is uploaded to our cloud were stored in JSON format (Figure 1), and data being uploaded by different sensors have their own unique URL. So, in our code, by searching the specific URL (Figure 2), we can get the information we need. | |
− | + | </p> | |
− | <p | + | <p> |
− | Since our | + | (Notice: Since our EDC sensor has not been made yet, so here we use the value detected by ultrasound for replacement. However, our detector’s mechanical design proposal and the software parts are ready.) |
− | + | </p> | |
− | <p>< | + | <p> |
− | + | <img width="50%" src="https://static.igem.org/mediawiki/2017/f/f3/T--NTHU_Taiwan--Applied_Design--App_Design_Code1.png"> | |
− | + | </p> | |
− | <p><font size= | + | <p><center><font size="2"> |
− | + | Figure 1 | |
− | </font></ | + | </font></center></p> |
− | |||
− | |||
− | |||
− | < | + | <img width="50%" src="https://static.igem.org/mediawiki/2017/e/e3/T--NTHU_Taiwan--Applied_Design--App_Design_Code2.png"> |
− | + | ||
− | + | ||
− | <p><font size= | + | <p><center><font size="2"> |
− | + | Figure 2 | |
− | </font></ | + | </font></center></p> |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | <p> | + | <p> |
− | + | 2. Parse JSON to retrieve specific data | |
− | </p | + | </p> |
− | <p> | + | <p> |
− | + | The JSON file we get from the server contains lots of information, such as API Version、Message、Device ID、Recorded time and Value, etc, therefore, in order to get a specific data in JSON file, we have to use a technique called parsing, to parse JSON Objects and JSON Arrays.(Figure 3) | |
− | + | </p> | |
− | Figure | + | |
− | + | ||
− | + | ||
− | </p | + | |
+ | <p> | ||
+ | (Notice: Since our EDC sensor has not been made yet, so here we use the value detected by ultrasound for replacement. However, our detector’s mechanical design proposal and the software parts are ready.) | ||
+ | </p> | ||
− | <p> | + | <p> |
− | <img width="50%" src="https://static.igem.org/mediawiki/2017/ | + | <img width="50%" src="https://static.igem.org/mediawiki/2017/9/95/T--NTHU_Taiwan--Applied_Design--App_Design_Code3.png"> |
− | </p | + | </p> |
− | <p> | + | <p><center><font size="2"> |
− | <center> | + | Figure 3 |
− | <font size="2"> | + | </font></center></p> |
− | Figure | + | |
− | </font> | + | |
− | </center> | + | |
− | </p | + | |
+ | <p> | ||
+ | 3. Display | ||
+ | </p> | ||
− | <p | + | <p> |
− | + | And finally, here is how we represent our data. | |
− | + | </p> | |
− | <p | + | <p> |
− | + | For Tab1 (Real-time detection value from a single detection point), we simply layout some TextView boxes, and let the text be changed to the value we got from JSON file. | |
− | + | </p> | |
− | <p>< | + | <p> |
− | + | <img width="50%" src="https://static.igem.org/mediawiki/2017/a/a4/T--NTHU_Taiwan--Applied_Design--App_Design_Code4.png"> | |
− | + | </p> | |
− | <p> | + | <p> |
− | + | For Tab2 (Historical monitoring data from a single detection point), we use GRAPH VIEW (http://www.android-graphview.org/showcase/ ) to display two of our data, which are temperature and concentration of EDC, with y-axis their values and x-axis the recorded time. | |
− | </p | + | </p> |
− | <p> | + | <p> |
− | + | (Notice: Since our EDC sensor has not been made yet, so here we use the value detected by ultrasound for replacement. However, our detector’s mechanical design proposal and the software parts are ready.) | |
− | + | </p> | |
− | + | ||
− | + | ||
− | + | ||
− | </p | + | |
+ | <img width="25%" src="https://static.igem.org/mediawiki/2017/5/5d/T--NTHU_Taiwan--Applied_Design--App_Design_UI1.png"> | ||
− | |||
− | |||
− | |||
− | <p | + | <p> |
− | + | As for Tab3 (The distribution of all detection points and their visualized EDC concentrations), in order to use google map in our application, we need to register to Google Developer Console for permission. | |
− | + | </p> | |
− | <p>< | + | <p> |
− | + | <img width="25%" src="https://static.igem.org/mediawiki/2017/4/42/T--NTHU_Taiwan--Applied_Design--App_Design_UI2.png"> | |
− | + | </p> | |
− | |||
− | |||
− | |||
− | < | + | <video width="960" height="720" controls> |
− | + | <source src="https://static.igem.org/mediawiki/2017/8/8e/T--NTHU_Taiwan--Applied_Design--App_Demo_Video.mp4" type="video/mp4"> | |
− | + | </video> | |
− | <p><font size= | + | <p><center><font size="2"> |
− | + | App Demo Video | |
− | </font></ | + | </font></center></p> |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | </div> | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | </ | + | |
− | + | ||
</div> | </div> | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
</html> | </html> |
Revision as of 09:50, 31 October 2017
Software
Software Design: IoT System and App
With the implementation of our device, we now can provide farmers a water protection system. Furthermore, we have developed an app and IoT system. The app will allow the user to know the condition of the farmland water, and the IoT system is set to save all the data and collaborate with other nearby protection systems to build up a “safe web.” When our devices are widely spread around a region, we would not only be able to help the farmers keep their farmland’ water source safe, but even identify when and where the pollution came from.
The IoT System
Why IoT?
In order to fulfill the purpose of data monitoring in real-time, we have to implement IoT system to our device. The implementation can be simply classified in the following steps:
1. Sensors (temperature, PH detector) collect data to our controller.
2. Controller upload data to cloud through wifi.
What have been used?
Cloud Platform : MediaTek Cloud Sandbox
We created an account on MediaTek Cloud Sandbox, therefore, our data will be going there.
After establishing an MCS account, we start to create our virtual device and data channel. When data channel is being created, they will have their own Device ID and Device Key. So, when writing our Arduino code and assign them with specific Device ID and Device Key, our data will be able to send to that data channel.
Controller and Sensors
The controller is the heart of our device, where it is responsible for receiving, processing, uploading data to the cloud, and also control our motor.
The reason why we choose MediaTek LinkIt™ ONE as our controller mainly because it has its own cloud platform MediaTek Cloud Sandbox, which enable us to implement IoT system to our device much easier. As for the sensors, right now we have used a thermometer and pH meter. Fluorescence detector will be added to the system once biochip has been successfully manufactured.
How we do this?
Step 1: Sensors collect data to our controller
This part is relatively simple, based on the sensors we use, we search for the corresponding code on the Internet, and copy them into our Arduino code (Figure 1). Once we have the code and correct PIN connected to our sensors, then we are good to go.
Step 2: Controller upload data to cloud through wifi
Remember the Device ID and Device Key that we mentioned before? In this part, we are going to use it. The function of them works like the address, when we assign specific Device ID and Device Key inside our code (Figure 2), our data can be correctly sent to the corresponding data channel.
The App Design
Why we built this APP?
The purpose of building this APP is that we hope to monitor values from our detection point in real-time.Furthermore, if we have multiple detection points in the future, we can label all data with different colors of markers according to their concentrations, and show them on the google map. Therefore, we can get regional concentrations at once, which enable us to identify sources of pollution with ease.
How do we build our APP?
The software we use is Android Studio. And we manage to represent our detection data in the following ways:
Tab1: Real-time detection value from a single detection point.
Tab2: Historical monitoring data from a single detection point.
Tab3: The distribution of all detection points and their visualized EDC concentrations.
Since our detection system has implemented Internet of Things (IoT), therefore, all data being detected will be stored to our cloud in JSON format (For details, please refer to DEVICE / Software – IoT page). So if we want to retrieve those data from our cloud, what we have to do can be simplified as followings:
1. Get JSON file from server.
2. Parse JSON to retrieve specific data.
3. Display.
Now we will go through those steps one by one :
1. Get JSON file from server
Data is uploaded to our cloud were stored in JSON format (Figure 1), and data being uploaded by different sensors have their own unique URL. So, in our code, by searching the specific URL (Figure 2), we can get the information we need.
(Notice: Since our EDC sensor has not been made yet, so here we use the value detected by ultrasound for replacement. However, our detector’s mechanical design proposal and the software parts are ready.)
2. Parse JSON to retrieve specific data
The JSON file we get from the server contains lots of information, such as API Version、Message、Device ID、Recorded time and Value, etc, therefore, in order to get a specific data in JSON file, we have to use a technique called parsing, to parse JSON Objects and JSON Arrays.(Figure 3)
(Notice: Since our EDC sensor has not been made yet, so here we use the value detected by ultrasound for replacement. However, our detector’s mechanical design proposal and the software parts are ready.)
3. Display
And finally, here is how we represent our data.
For Tab1 (Real-time detection value from a single detection point), we simply layout some TextView boxes, and let the text be changed to the value we got from JSON file.
For Tab2 (Historical monitoring data from a single detection point), we use GRAPH VIEW (http://www.android-graphview.org/showcase/ ) to display two of our data, which are temperature and concentration of EDC, with y-axis their values and x-axis the recorded time.
(Notice: Since our EDC sensor has not been made yet, so here we use the value detected by ultrasound for replacement. However, our detector’s mechanical design proposal and the software parts are ready.)
As for Tab3 (The distribution of all detection points and their visualized EDC concentrations), in order to use google map in our application, we need to register to Google Developer Console for permission.