Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

VDMS 2.7.0 Release #168

Merged
merged 46 commits into from
Jan 5, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
f8fdeda
Docker dep (#65)
cwlacewe Oct 11, 2022
00cfc42
Publicly available docker image (develop) (#151)
cwlacewe Oct 11, 2022
476dbe8
Update workflow to use different runner (#72)
cwlacewe Nov 7, 2022
2673edb
Add SDL/OSPDT requirements (#73)
cwlacewe Nov 23, 2022
0321712
Add python coverage to workflow and protobuf code for python client (…
cwlacewe Dec 13, 2022
726b642
Update dockerfiles (#81)
cwlacewe Jan 26, 2023
fccb2eb
Add generic AddBlob command (#79)
Ragaad Mar 6, 2023
2582340
Update python coerage test to exclude tests folder (#86)
cwlacewe Mar 10, 2023
55fd710
Fix TestFindDescriptors.py (#88)
cwlacewe Mar 10, 2023
3e822bb
Unify ports for unit tests (#92)
cwlacewe Mar 15, 2023
beda7a5
csv client lib (#78)
Ragaad Mar 24, 2023
711d370
Update CI Workflow (#90)
cwlacewe Mar 27, 2023
c005611
89 upgrade GitHub actions workflow (#97)
cwlacewe Mar 27, 2023
5cb0431
89 upgrade GitHub actions workflow (#99)
cwlacewe Mar 27, 2023
e97b93f
98 fix snyk vulnerabilities (#100)
cwlacewe Mar 28, 2023
6935608
89 upgrade GitHub actions workflow (#102)
cwlacewe Mar 28, 2023
a845573
89 upgrade GitHub actions workflow (#103)
cwlacewe Mar 28, 2023
2271a58
89 upgrade GitHub actions workflow (#104)
cwlacewe Mar 28, 2023
bafc5dd
Fix workflow permission issue occurring after multiple runs (#105)
cwlacewe Mar 31, 2023
acffe32
Fix snyk vulnerability (#107)
cwlacewe Apr 3, 2023
12dd421
Update Pypi for v2.4.0 (#108)
cwlacewe Apr 3, 2023
3f1473f
Fix Coverity Issues for v2.4.0 (#110)
cwlacewe Apr 6, 2023
2812703
Remove internal files
cwlacewe Apr 6, 2023
d25eb7b
Remove MAVEN and update INSTALL.md (#111)
cwlacewe Apr 6, 2023
ac683f4
Merge branch 'develop' into v2.4.0
cwlacewe Apr 6, 2023
1477a02
Merge branch 'master' into v2.4.0
cwlacewe Apr 6, 2023
c5ebbb7
Add new security.md file
cwlacewe Apr 6, 2023
c1b656f
V2.4.0 Release (#112)
cwlacewe Apr 7, 2023
9ba75ea
Add required Security file
cwlacewe Apr 7, 2023
b303d02
CSV Plugin updates for v2.4.0 (#118)
cwlacewe Apr 14, 2023
9ddb972
Merge branch 'develop' into v2.4.0
cwlacewe Apr 14, 2023
258735e
Merge branch 'v2.4.0'
cwlacewe Apr 14, 2023
f09aaf5
VDMS 2.4.0 Release (#155)
cwlacewe Apr 17, 2023
58eaf53
Update v2.4.0 Dockerfile (#158)
cwlacewe Apr 17, 2023
2a3f0e1
Update Base Dockerfile
cwlacewe Apr 17, 2023
6e04466
v2.5.0 Release (#168)
cwlacewe Aug 9, 2023
5ac6fc0
VDMS 2.5.0 Release (#160)
cwlacewe Aug 9, 2023
99af889
Update Dockerfile
cwlacewe Aug 9, 2023
1d7f356
Update Dockerfile
cwlacewe Aug 9, 2023
06582bd
V2.6.0 (#206)
cwlacewe Oct 4, 2023
f5548b0
VDMS 2.6.0 Release (#163)
cwlacewe Oct 4, 2023
1dc8395
Release V2.7.0 (#239)
cwlacewe Jan 4, 2024
7b2fbc4
Merge remote-tracking branch 'upstream/develop' into develop
cwlacewe Jan 5, 2024
72facb2
Merge branch 'master' of https://github.com/cwlacewe/vdms
cwlacewe Jan 5, 2024
232e088
Merge branch 'develop'
cwlacewe Jan 5, 2024
de2869b
Update setup.py
cwlacewe Jan 5, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
112 changes: 56 additions & 56 deletions INSTALL.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,8 @@ To install VDMS, we must install the necessary dependencies via apt, github, and
### Install Debian/Ubuntu Packages
Here we will install the Debian/Ubuntu packages.
```bash
sudo apt-get update
sudo apt-get update -y --fix-missing
sudo apt-get upgrade -y
sudo apt-get install -y --no-install-suggests --no-install-recommends \
apt-transport-https autoconf automake bison build-essential bzip2 ca-certificates \
curl ed flex g++-9 gcc-9 git gnupg-agent javacc libarchive-tools libatlas-base-dev \
Expand Down Expand Up @@ -55,7 +56,17 @@ alias python=/usr/bin/python3
You can also install the coverage package if interested in running the Python unit tests.
```bash
python3 -m pip install --upgrade pip
python3 -m pip install --no-cache-dir "numpy>=1.25.1" "coverage>=7.2.7"
python3 -m pip install --no-cache-dir "numpy>=1.26.0" "coverage>=7.3.1"
```


#### **Valijson v0.6**
This is a headers-only library, no compilation/installation necessary.
```bash
VALIJSON_VERSION="v0.6"
git clone --branch ${VALIJSON_VERSION} https://github.com/tristanpenman/valijson.git $VDMS_DEP_DIR/valijson
cd $VDMS_DEP_DIR/valijson
sudo cp -r include/* /usr/local/include/
```


Expand All @@ -71,36 +82,11 @@ sudo make install
```


#### **Faiss v1.7.3**
Install the Faiss library for similarity search.
```bash
FAISS_VERSION="v1.7.3"
git clone --branch ${FAISS_VERSION} https://github.com/facebookresearch/faiss.git $VDMS_DEP_DIR/faiss
cd $VDMS_DEP_DIR/faiss
mkdir build && cd build
cmake -DFAISS_ENABLE_GPU=OFF -DPython_EXECUTABLE=/usr/bin/python3 ..
make ${BUILD_THREADS}
sudo make install
```


#### **FLINNG**
Install the Filters to Identify Near-Neighbor Groups (FLINNG) library for similarity search.
```bash
git clone https://github.com/tonyzhang617/FLINNG.git $VDMS_DEP_DIR/FLINNG
cd $VDMS_DEP_DIR/FLINNG
mkdir build && cd build
cmake ..
make ${BUILD_THREADS}
sudo make install
```


#### **Protobuf v24.2 (4.24.2)**
Install Protobuf (C++ and Python) which requires GoogleTest and Abseil C++ as dependencies.
```bash
PROTOBUF_VERSION="24.2"
git clone -b v${PROTOBUF_VERSION} --recursive https://github.com/protocolbuffers/protobuf.git $VDMS_DEP_DIR/protobuf
git clone -b v${PROTOBUF_VERSION} --recurse-submodules https://github.com/protocolbuffers/protobuf.git $VDMS_DEP_DIR/protobuf

cd $VDMS_DEP_DIR/protobuf/third_party/googletest
mkdir build && cd build
Expand Down Expand Up @@ -128,42 +114,31 @@ python3 -m pip install --no-cache-dir "protobuf==4.${PROTOBUF_VERSION}"
```


#### **[OpenCV](https://opencv.org/) 4.5.5**
Below are instructions for installing ***OpenCV v4.5.5***.
#### **Faiss v1.7.3**
Install the Faiss library for similarity search.
```bash
OPENCV_VERSION="4.5.5"
git clone --branch ${OPENCV_VERSION} https://github.com/opencv/opencv.git $VDMS_DEP_DIR/opencv
cd $VDMS_DEP_DIR/opencv
FAISS_VERSION="v1.7.3"
git clone --branch ${FAISS_VERSION} https://github.com/facebookresearch/faiss.git $VDMS_DEP_DIR/faiss
cd $VDMS_DEP_DIR/faiss
mkdir build && cd build
cmake -D BUILD_PERF_TESTS=OFF -D BUILD_TESTS=OFF ..
cmake -DFAISS_ENABLE_GPU=OFF -DPython_EXECUTABLE=/usr/bin/python3 ..
make ${BUILD_THREADS}
sudo make install
```

**Note**: When using videos, and getting the following error: "Unable to stop the stream: Inappropriate ioctl for device", you may need to include more flags when compiling OpenCV. Follow these instructions ([source](https://stackoverflow.com/questions/41200201/opencv-unable-to-stop-the-stream-inappropriate-ioctl-for-device)):
```bash
apt-get install ffmpeg
apt-get install libavcodec-dev libavformat-dev libavdevice-dev

cmake -D BUILD_PERF_TESTS=OFF -D BUILD_TESTS=OFF -D CMAKE_BUILD_TYPE=RELEASE -D CMAKE_INSTALL_PREFIX=/usr/local \
-D WITH_FFMPEG=ON -D WITH_TBB=ON -D WITH_GTK=ON \
-D WITH_V4L=ON -D WITH_OPENGL=ON -D WITH_CUBLAS=ON \
-DWITH_QT=OFF -DCUDA_NVCC_FLAGS="-D_FORCE_INLINES" ..
#### **FLINNG**
Install the Filters to Identify Near-Neighbor Groups (FLINNG) library for similarity search.
```bash
git clone https://github.com/tonyzhang617/FLINNG.git $VDMS_DEP_DIR/FLINNG
cd $VDMS_DEP_DIR/FLINNG
mkdir build && cd build
cmake ..
make ${BUILD_THREADS}
sudo make install
```


#### **Valijson v0.6**
This is a headers-only library, no compilation/installation necessary.
```bash
VALIJSON_VERSION="v0.6"
git clone --branch ${VALIJSON_VERSION} https://github.com/tristanpenman/valijson.git $VDMS_DEP_DIR/valijson
cd $VDMS_DEP_DIR/valijson
sudo cp -r include/* /usr/local/include/
```


#### **[TileDB](https://tiledb.io/) 2.14.1**
The directions below will help you install TileDB v2.14.1 from the source.
You can also follow the directions listed [here](https://docs.tiledb.io/en/latest/installation.html).
Expand Down Expand Up @@ -191,28 +166,53 @@ cmake .. -DCMAKE_BUILD_TYPE=Debug -DCMAKE_PREFIX_PATH=/usr/local/ -DCMAKE_INSTAL
make ${BUILD_THREADS}
sudo make install
```


#### **[OpenCV](https://opencv.org/) 4.5.5**
Below are instructions for installing ***OpenCV v4.5.5***.
```bash
OPENCV_VERSION="4.5.5"
git clone --branch ${OPENCV_VERSION} https://github.com/opencv/opencv.git $VDMS_DEP_DIR/opencv
cd $VDMS_DEP_DIR/opencv
mkdir build && cd build
cmake -D BUILD_PERF_TESTS=OFF -D BUILD_TESTS=OFF ..
make ${BUILD_THREADS}
sudo make install
```

**Note**: When using videos, and getting the following error: "Unable to stop the stream: Inappropriate ioctl for device", you may need to include more flags when compiling OpenCV. Follow these instructions ([source](https://stackoverflow.com/questions/41200201/opencv-unable-to-stop-the-stream-inappropriate-ioctl-for-device)):
```bash
sudo apt-get install -y ffmpeg
sudo apt-get install -y libavdevice-dev

cmake -D BUILD_PERF_TESTS=OFF -D BUILD_TESTS=OFF -D CMAKE_BUILD_TYPE=RELEASE -D CMAKE_INSTALL_PREFIX=/usr/local \
-D WITH_FFMPEG=ON -D WITH_TBB=ON -D WITH_GTK=ON \
-D WITH_V4L=ON -D WITH_OPENGL=ON -D WITH_CUBLAS=ON \
-DWITH_QT=OFF -DCUDA_NVCC_FLAGS="-D_FORCE_INLINES" ..
make ${BUILD_THREADS}
sudo make install
```
<br>

## Install VDMS
This version of VDMS treats PMGD as a submodule so both libraries are compiled at one time. After entering the vdms directory, the command `git submodule update --init --recursive` will pull pmgd into the appropriate directory. Furthermore, Cmake is used to compile all directories.
```bash
git clone -b develop https://github.com/IntelLabs/vdms.git
git clone -b develop --recurse-submodules https://github.com/IntelLabs/vdms.git
cd vdms
git submodule update --init --recursive
```

When compiling on a target without Optane persistent memory, use the following:
```bash
mkdir build && cd build
cmake ..
make -j
make ${BUILD_THREADS}
cp ../config-vdms.json .
```

When compiling on a target with Optane persistent memory, use the command set:
```bash
mkdir build && cd build
cmake -DCMAKE_CXX_FLAGS='-DPM' ..
make -j
make ${BUILD_THREADS}
```

2 changes: 1 addition & 1 deletion client/python/setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@

setuptools.setup(
name="vdms",
version="0.0.19",
version="0.0.20",
author="Chaunté W. Lacewell",
author_email="[email protected]",
description="VDMS Client Module",
Expand Down
38 changes: 29 additions & 9 deletions client/python/vdms/vdms.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,17 @@
class vdms(object):
def __init__(self):
self.dataNotUsed = []
self.init_connection()
self.last_response = ""

def __del__(self):
self.conn.close()
self.connected = False

def init_connection(self):
if hasattr(self, "conn") and self.conn is not None:
self.conn.close()

self.conn = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
self.conn.setsockopt(socket.SOL_TCP, socket.TCP_NODELAY, 1)

Expand All @@ -51,20 +62,29 @@ def __init__(self):
# https://docs.python.org/dev/library/sys.html#sys.platform
if sys.platform.startswith("linux"):
self.conn.setsockopt(socket.SOL_TCP, socket.TCP_QUICKACK, 1)

self.connected = False
self.last_response = ""

def __del__(self):
self.conn.close()

def connect(self, host="localhost", port=55555):
self.conn.connect((host, port))
self.connected = True
if self.connected is False:
self.init_connection()
self.conn.connect((host, port))
self.connected = True
return True
else:
print("Connection is already active")
return False

def disconnect(self):
self.conn.close()
self.connected = False
if self.connected is True:
self.conn.close()
self.connected = False
return True
else:
print("There is not an active connection")
return False

def is_connected(self):
return self.connected

# Recieves a json struct as a string
def query(self, query, blob_array=[]):
Expand Down
4 changes: 3 additions & 1 deletion config-vdms.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,9 @@
// "backup_path":"backups_test", // set this if you want different path to store the back up file
"db_root_path": "db",
"backup_flag" : "false",
"storage_type": "local", //local, aws, etc
"storage_type": "local", //local, aws
// use_endpoint: [true|false] in case of "storage_type" is equals to "aws", this key is used to specify whether it is going to use a "mocked" AWS connection
"use_endpoint": false,
"bucket_name": "minio-bucket",
"more-info": "github.com/IntelLabs/vdms"
}
Loading