Connecting and Controlling a Motorized Ball Valve

This tutorial will give you an overview of the core features of the board, setup the development environment and introduce the required APIs to program the board.

Overview

A ball valve is a form of quarter-turn valve which uses a hollow, perforated and pivoting ball to control flow of liquids and gasses through it. This tutorial will guide you through connecting the board to a 3 Wire-Valve and writing a sketch that controls the basic operations such as the opening and closing of the valves.

Tip : If this is for your first Edge Control project, we recommend you to take a look at the Getting Started Tutorial to setup the development environment before you proceed.

Goals

  • How to connect a motorized valve to the Edge Control board
  • How to control the valve through basic commands provided by the
    Arduino_EdgeControl
    library
  • How to power the board with an external power supply

Required Hardware and Software

Instructions

1. Connecting the Valves

The motorized valve comes with three wires primarily marked as blue, yellow and red. The red and blue cables are for the positive and negative signals and the yellow is for the ground.

Schematics of the 3 wire motor

Before you attach the wires to the board you need to ensure that the Phoenix connectors are in place

The Latching Circuitry A Latching Circuit has 2 inputs for Positive(P) and Negative(N) signals and 1 output. Latches allows you to store the previous state of the signal that passes through either of the pins and maintains the state until you pass a new signal. Signal passed through the positive and the negative pins will also determine the direction of the signal to the valve. The Edge Control board comes with 8 pairs of Latches each labeled from 1N:1P up to 8N:8P.

Connect the red and the blue wire to

1N
and
1P
of your Edge Control board. As the valve doesn't come with internal drivers to store the state of the motor, we will use the
Latching_out
pins, instead of
Latching_out_cmd
, these are the ones that include drivers on the Edge Control.

Connecting the valves to the connectors

Connect the yellow wire to the nearby

GND
pin. Ensure that the wires are fastened securely and tightly to the connectors so that they make contact with the pins.

2. Opening And Closing the Valves

Open a new sketch file on the Arduino IDE and name it

ValveControl.ino
. Add the header file
Arduino_EdgeControl.h
to your sketch.

1#include <Arduino_EdgeControl.h>

Inside

void setup()
, after enabling the serial communication, run the initialization routine
EdgeControl.begin()
. This routine is in charge of enabling the default power areas of the board. Then use
Latching.begin()
to configure the expander pins as outputs.

1void setup(){
2 Serial.begin(9600);
3 while(!Serial);
4
5 delay(1000);
6
7 Serial.println("3-Wire Valve Demo");
8
9 EdgeControl.begin();
10 Latching.begin();
11
12 Serial.println("Starting");
13}

As mentioned earlier, the 2 Input Pins of the latching circuit are primarily used to control the direction of the output signal. The

<Arduino_EdgeControl.h>
provides various methods to access and control these pins. The command
Latching.channelDirection(LATCHING_OUT_1, direction)
is a method that can be used to assign a signal direction to a specific pin on the board through the parameters.

Inside the

loop()
you will add the instructions to open and close the valve.
Latching.channelDirection()
with the parameter
LATCHING_OUT_1
to access the 1N:1P pins and the parameters,
POSITIVE
or
NEGATIVE
for the direction. If you want the valve to open you can use the function as such,

1Latching.channelDirection(LATCHING_OUT_1, POSITIVE)

and to close the valve, you need to send a signal in the opposite direction using the command,

1Latching.channelDirection(LATCHING_OUT_1, NEGATIVE)

As it takes a few seconds for the valve to fully open or close, you need to maintain the signal for a set amount of time. Using the command,

Latching.strobe(4500)
you can adjust the duration (milliseconds) of a signal passing through a particular pin.

1void loop(){
2 Serial.println("Closing");
3 Latching.channelDirection(LATCHING_OUT_1, POSITIVE);
4 Latching.strobe(4500);
5 delay(2500);
6
7 Serial.println("Opening");
8 Latching.channelDirection(LATCHING_OUT_1, NEGATIVE);
9 Latching.strobe(4500);
10 delay(2500);
11}

3. Connecting To A Power Source

The valves require a power supply of 9 - 12 V and you can either use a regular power supply or a 3 cell LiPo battery to provide the required voltage. Power sources can be connected to the relay ports on the edge control board, ensure that you have a source that can provide 9 - 12 V of power for both the valve and the board. Connect two jumper wires to the GND and B pins of the Relay ports.

The power pins of the Edge Control

Connect the jumper from the B pin to the positive terminal of the battery and the jumper from the GND pin to the negative terminal of the battery.

4. Uploading the Sketch

Connect the board to your computer, upload the

ValveControl.ino
sketch and open the Serial Monitor. If all the connections are done right, the valve opens and closes and you should be able to see the status as
Open
or
Close
on the serial monitor.

Conclusion

In this tutorial you learned how a 3 wire valve works and the basic operations that the Edge Control board uses to control the valves. With this knowledge you can build irrigation systems that periodically control the valves, which can be installed in your fields.

Complete Sketch

1#include <Arduino_EdgeControl.h>
2
3void setup(){
4 Serial.begin(9600);
5 while(!Serial);
6
7 delay(1000);
8
9 Serial.println("3-Wire Valve Demo");
10
11 EdgeControl.begin();
12 Latching.begin();
13
14 Serial.println("Starting");
15}
16
17void loop(){
18 Serial.println("Closing");
19 Latching.channelDirection(LATCHING_OUT_1, POSITIVE);
20 Latching.strobe(4500);
21 delay(2500);
22
23 Serial.println("Opening");
24 Latching.channelDirection(LATCHING_OUT_1, NEGATIVE);
25 Latching.strobe(4500);
26 delay(2500);
27}

Suggest changes

The content on docs.arduino.cc is facilitated through a public GitHub repository. If you see anything wrong, you can edit this page here.

License

The Arduino documentation is licensed under the Creative Commons Attribution-Share Alike 4.0 license.