Skip to content

Commit

Permalink
Merge branch 'main' into dev
Browse files Browse the repository at this point in the history
  • Loading branch information
fanyinbo committed Nov 13, 2024
2 parents ddaf7cb + 4543067 commit 357e930
Show file tree
Hide file tree
Showing 11 changed files with 148 additions and 46 deletions.
2 changes: 1 addition & 1 deletion .ops/.gitlab-ci.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
include:
- project: 'basicai/xtreme1/common'
file: '/ci/template/xtreme1-app.yml'
file: '/ops/ci/template/xtreme1-app.yml'

variables:
APP_NAME: "xtreme1"
Expand Down
9 changes: 3 additions & 6 deletions .ops/deploy/backend/base/backend.yml
Original file line number Diff line number Diff line change
Expand Up @@ -34,22 +34,19 @@ spec:
httpGet:
path: /actuator/health/liveness
port: 8080
periodSeconds: 10
failureThreshold: 6
# 默认 periodSeconds 为 10s,failureThreshold 为 3 次,那么默认的等待时长为 10 * 3 = 30s,
# 对于启动比较慢的 Java 应用不太够,需要上调 periodSeconds 或 failureThreshold
failureThreshold: 10
# 存活探针,会尝试多次,如果失败将重启服务
livenessProbe:
httpGet:
path: /actuator/health/liveness
port: 8080
periodSeconds: 10
failureThreshold: 3
# 就绪探针,如果失败将拒绝服务
readinessProbe:
httpGet:
path: /actuator/health/readiness
port: 8080
initialDelaySeconds: 10
periodSeconds: 10
volumeMounts:
- name: config
mountPath: /app/config
Expand Down
4 changes: 2 additions & 2 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,8 @@ As you can see from [Xtreme1 GitHub](https://github.com/xtreme1-io/xtreme1), Xtr

| Component Name | Component Description | Related Language |
|----------------|-----------------------|------------------|
| [Frontend (FE)](https://github.com/xtreme1-io/xtreme1) | Xtreme1 web ui | Java |
| [Backend (BE)](https://github.com/xtreme1-io/xtreme1) | Xtreme1 api service | JavaScript, TypeScript, HTML, CSS |
| [Frontend (FE)](https://github.com/xtreme1-io/xtreme1) | Xtreme1 web ui | JavaScript, TypeScript, HTML, CSS |
| [Backend (BE)](https://github.com/xtreme1-io/xtreme1) | Xtreme1 api service | Java |
| [Docs](https://github.com/xtreme1-io/docs) | Xtreme1 documents | Markdown |

## Improving documentation
Expand Down
156 changes: 127 additions & 29 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,31 +4,24 @@
![](https://img.shields.io/badge/Release-v0.9.1-green)
![](https://img.shields.io/badge/License-Apache%202.0-blueviolet)
[![Twitter](https://img.shields.io/badge/Follow-Twitter-blue)](https://twitter.com/Xtreme1io)
[![Online](https://img.shields.io/badge/Xtreme1_Online-App-yellow)](https://app.basic.ai/#/login)
[![Docs](https://img.shields.io/badge/Docs-Stable-success.svg?style=flat&longCache=true)](http://docs.xtreme1.io/)

[![Use Cloud for Free](https://basicai-asset.s3.amazonaws.com/docs/Open-source/Operation/App_Button.png)](https://app.basic.ai/login)
[![Use Cloud for Free](https://basicai-asset.s3.amazonaws.com/docs/Open-source/Operation/App_Button.png)](https://app.basic.ai)
</div>

# Intro
Xtreme1 is an all-in-one open-source platform for Multimodal training data.
# Intro

Xtreme1 unlocks efficiency in data annotation, curation, and ontology management for tackling machine learning challenges in computer vision and LLM. The platform's AI-fueled tools elevate your annotation to the next efficiency level, powering your projects in 2D/3D Object Detection, 3D Instance Segmentation, and LiDAR-Camera Fusion like never before.
Xtreme1 is an all-in-one open-source platform for multimodal training data.

A long-term free plan is offered in the Xtreme1 Cloud version. Click to [🎉 Use Cloud for Free](https://app.basic.ai/login).
Xtreme1 unlocks efficiency in data annotation, curation, and ontology management for tackling machine learning challenges in computer vision and LLM. The platform's AI-fueled tools elevate your annotation to the next efficiency level, powering your projects in 2D/3D Object Detection, 2D/3D Semantic/Instance Segmentation, and LiDAR-Camera Fusion like never before.

# Documentation
A long-term free plan is offered in the Xtreme1 Cloud version. Click to [🎉 Use Cloud for Free](https://app.basic.ai).

🎆 Welcome aboard! If you have any questions or doubts about features, installation, development, and deployment, you can always refer to our documentation.
The README document only includes content related to installation, building, and running, if you have any questions or doubts about features, you can always refer to our [Docs Site](https://docs.xtreme1.io/xtreme1-docs/).

[📙 Find our docs here! ](https://docs.xtreme1.io/xtreme1-docs/)
Find us on [Twitter](https://twitter.com/Xtreme1io) | [Medium](https://medium.com/multisensory-data-training) | [Issues](https://github.com/xtreme1-io/xtreme1/issues)


# Find Us
[Twitter](https://twitter.com/Xtreme1io) | [Medium](https://medium.com/multisensory-data-training) | [Issues](https://github.com/xtreme1-io/xtreme1/issues)


# Key features
# Key Features

Image Annotation (B-box, Segmentation) - [YOLOR](https://github.com/WongKinYiu/yolor) & [RITM](https://github.com/saic-vul/ritm_interactive_segmentation) | Lidar-camera Fusion Annotation - [OpenPCDet](https://github.com/open-mmlab/OpenPCDet) & [AB3DMOT](https://github.com/xinshuoweng/AB3DMOT)
:-------------------------:|:-------------------------:
Expand All @@ -48,44 +41,95 @@ Image Annotation (B-box, Segmentation) - [YOLOR](https://github.com/WongKinYiu/y

:seven: RLHF for Large Language Models :new: (beta version)

Image Data Curation (Visualizing & Debug) - [MobileNetV3](https://github.com/xiaolai-sqlai/mobilenetv3) & [openTSNE](https://github.com/pavlin-policar/openTSNE) | RLHF Annotation tool for LLM (beta version)
Image Data Curation (Visualizing & Debug) - [MobileNetV3](https://github.com/xiaolai-sqlai/mobilenetv3) & [openTSNE](https://github.com/pavlin-policar/openTSNE) | RLHF Annotation Tool for LLM (beta version)
:-------------------------:|:-------------------------:
![](/docs/images/2d_v.gif) | <img src="/docs/images/0.7rlhf.webp" width="640">

# Quick start
# Install

## Prerequisites

*Operating System Requirements*

Any OS can install the Xtreme1 platform with Docker Compose (installing [Docker Desktop](https://docs.docker.com/desktop/) on Mac, Windows, and Linux devices). On the Linux server, you can install Docker Engine with [Docker Compose Plugin](https://docs.docker.com/compose/install/linux/).

*Hardware Requirements*

**CPU**: AMD64 or ARM64
**RAM**: 2GB or higher
**Hard Drive**: 10GB+ free disk space (depends on data size)

*Software Requirements*

For Mac, Windows, and Linux with desktop.

**Docker Desktop**: 4.1 or newer

For Linux server.

**Docker Engine**: 20.10 or newer
**Docker Compose Plugin**: 2.0 or newer

* Get access to [Xtreme1 online version](https://app.basic.ai/#/login/) without any installation :rocket:
*(Built-in) Models Deployment Requirements*

* [Install and Quick start](https://docs.xtreme1.io/xtreme1-docs/get-started/quick-start) :cd:
* [Install with Docker](https://docs.xtreme1.io/xtreme1-docs/get-started/install-with-docker) 🐋
* [Build Xtreme1 from source code](https://docs.xtreme1.io/xtreme1-docs/get-started/install-from-source) :wrench:
The built-in model containers only can be running on Linux server with [NVIDIA CUDA Driver](https://docs.nvidia.com/cuda/cuda-installation-guide-linux/index.html) and [NVIDIA Container Toolkit](https://docs.nvidia.com/datacenter/cloud-native/container-toolkit/latest/index.html).

**GPU**: NVIDIA T4 or other similar GPU
**RAM**: 4G or higher

## Install with Docker

### Download Package

## Download package
Download the latest release package and unzip it.

```bash
wget https://github.com/xtreme1-io/xtreme1/releases/download/v0.9.1/xtreme1-v0.9.1.zip
unzip -d xtreme1-v0.9.1 xtreme1-v0.9.1.zip
```

## Start all services
### Start Services

Enter into the release package directory, and execute the following command to start all services. It needs a few minutes to initialize database and prepare a test dataset.

```bash
cd xtreme1-v0.9.1
docker compose up
```

Visit [http://localhost:8190](http://localhost:8190) in the browser (Google Chrome is recommended) to try out Xtreme1!
Visit [http://localhost:8190](http://localhost:8190) in the browser (Google Chrome is recommended) to try out Xtreme1! You can replace localhost with IP address if you want to access from another machine.

Docker compose will pull all service images from Docker Hub, including basic services `MySQL`, `Redis`, `MinIO`, and application services `backend`, `frontend`. You can find the username, password, hot binding port to access MySQL, Redis and MinIO in `docker-compose.yml`, for example you can access MinIO console at http://localhost:8194. We use Docker volume to save data, so you won't lose any data between container recreating.

Docker Compose advanced commands:

```bash
# Start in the foreground.
docker compose up

# Or add -d option to run in the background.
docker compose up -d

# When finished, you can start or stop all or specific services.
docker compose start
docker compose stop

# Stop all services and delete all containers, but data volumes will be kept.
docker compose down

# Danger! Delete all volumes. All data in MySQL, Redis and MinIO.
docker compose down -v
```

### Start Built-in Models

## ⚠️ Install built-in models
You need to explicitly specify a model profile to enable model services.

```bash
docker compose --profile model up
```

## Enable model services

> Make sure you have installed [NVIDIA Driver](https://docs.nvidia.com/datacenter/tesla/tesla-installation-notes/index.html) and [NVIDIA Container Toolkit](https://docs.nvidia.com/datacenter/cloud-native/container-toolkit/install-guide.html#docker). But you do not need to install the CUDA Toolkit, as it already contained in the model image.
Make sure you have installed [NVIDIA CUDA Driver](https://docs.nvidia.com/cuda/cuda-installation-guide-linux/index.html) and [NVIDIA Container Toolkit](https://docs.nvidia.com/datacenter/cloud-native/container-toolkit/latest/index.html) on host machine.

```bash
# You need set "default-runtime" as "nvidia" in /etc/docker/daemon.json and restart docker to enable NVIDIA Container Toolkit
Expand All @@ -99,9 +143,63 @@ docker compose --profile model up
"default-runtime": "nvidia"
}
```

If you use **Docker Desktop** + **WSL2.0**, please find this [issue #144](https://github.com/xtreme1-io/xtreme1/issues/144) for your reference.

![](/docs/images/3d_annotation2.png)
### Run on ARM CPU

Please note that certain Docker images, including `MySQL`, may not be compatible with the ARM architecture. In case your computer is based on an ARM CPU (e.g. Apple M1), you can create a Docker Compose override file called docker-compose.override.yml and include the following content. While this method uses QEMU emulation to enforce the use of the ARM64 image on the ARM64 platform, it may impact performance.

```yaml
services:
mysql:
platform: linux/amd64
```
## Install from Source
If you want to build or extend the function, download the source code and run locally.
### Enable Docker BuildKit
We are using Docker BuildKit to accelerate the building speed, such as cache Maven and NPM packages between builds. By default BuildKit is not enabled in Docker Desktop, you can enable it as follows. For more details, you can check the official document [Build images with BuildKit](https://docs.docker.com/develop/develop-images/build_enhancements/).
```bash
# Set the environment variable to enable BuildKit just for once.
DOCKER_BUILDKIT=1 docker build .
DOCKER_BUILDKIT=1 docker compose up

# Or edit Docker daemon.json to enable BuildKit by default, the content can be something like '{ "features": { "buildkit": true } }'.
vi /etc/docker/daemon.json

# You can clear the builder cache if you encounter some package version related problem.
docker builder prune
```

### Clone Repository

```bash
git clone https://github.com/basicai/xtreme1.git
cd xtreme1
```

### Build Images and Run Services

The `docker-compose.yml` default will pull application images from Docker Hub, if you want to build images from source code, you can comment on the service's image line and un-comment build line.

```yaml
services:
backend:
# image: basicai/xtreme1-backend
build: ./backend
frontend:
# image: basicai/xtreme1-frontend
build: ./frontend
```
Then when you run `docker compose up`, it will first build the `backend` and `frontend` image and start these services. Be sure to run `docker compose build` when code changes, as the up command will only build images when it does not exist.

> You should not commit your change to `docker-compose.yml`, to avoid this, you can copy docker-compose.yml to a new file `docker-compose.develop.yml`, and modify this file as your development needs, as this file is already added into `.gitignore`. And you need to specify this specific file when running Docker Compose commands, such as `docker compose -f docker-compose.develop.yml build`.

# License
This software is licensed under the Apache 2.0 LICENSE. Xtreme1 is a trademark of LF AI & Data Foundation.
Expand Down
2 changes: 1 addition & 1 deletion backend/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ RUN --mount=type=cache,target=/root/.m2 mvn package
FROM openjdk:11-jre
RUN apt update && \
apt install -y iputils-ping curl wget netcat python3 python3-pip git
RUN pip3 install --upgrade --force-reinstall git+https://github.com/xtreme1-io/xtreme1-sdk.git@d0cf4cc
RUN pip3 install --upgrade --force-reinstall git+https://github.com/xtreme1-io/xtreme1-sdk.git@6b53a73
WORKDIR /app
COPY --from=build /build/target/xtreme1-backend-0.9.1-SNAPSHOT.jar ./app.jar
RUN mkdir -p config
Expand Down
2 changes: 1 addition & 1 deletion backend/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
</parent>

<groupId>ai.basic</groupId>
<artifactId>xtreme1</artifactId>
<artifactId>xtreme1-backend</artifactId>
<version>0.9.1-SNAPSHOT</version>

<properties>
Expand Down
10 changes: 8 additions & 2 deletions backend/src/main/java/ai/basic/x1/usecase/ExportUseCase.java
Original file line number Diff line number Diff line change
Expand Up @@ -144,20 +144,26 @@ private <Q extends BaseQueryBO> void getDataAndUpload(ExportRecord record, Strin
var zipPath = srcPath + ".zip";
File zipFile;
var path = String.format("%s/%s", rootPath, FileUtil.getName(zipPath));

if (DataFormatEnum.COCO.equals(query.getDataFormat())) {
var basePath = String.format("%s/%s", tempPath, IdUtil.fastSimpleUUID());
var respPath = String.format("%s/resp.json", basePath);
var baseOutPath = String.format("%s/%s", basePath, FileUtil.getPrefix(zipPath));
var outPathNew = String.format("%s/result", baseOutPath);
FileUtil.move(Path.of(String.format("%s/image", srcPath)), Path.of(String.format("%s/image", baseOutPath)), true);
//FileUtil.move(Path.of(String.format("%s/image", srcPath)), Path.of(String.format("%s/image", baseOutPath)), true);
ZipUtil.zip(srcPath, zipPath, true);
FileUtil.mkdir(outPathNew);
DataFormatUtil.convert(Constants.CONVERT_EXPORT, zipPath, outPathNew, respPath);
if (FileUtil.exist(respPath) && UsecaseCode.OK.equals(DefaultConverter.convert(JSONUtil.readJSONObject(FileUtil.file(respPath), Charset.defaultCharset()), ApiResult.class).getCode())) {
zipFile = ZipUtil.zip(baseOutPath, zipPath, true);
} else {
FileUtil.del(basePath);
throw new UsecaseException("convert coco error");
var exportRecordBO = exportRecordBOBuilder
.status(ExportStatusEnum.FAILED)
.updatedAt(OffsetDateTime.now())
.build();
exportRecordUsecase.saveOrUpdate(exportRecordBO);
return;
}
FileUtil.del(basePath);
} else {
Expand Down
2 changes: 1 addition & 1 deletion backend/src/main/java/ai/basic/x1/util/DataFormatUtil.java
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ public static void convert(String type, String srcPath, String outPath, String r
FileUtil.mkParentDirs(respPath);
ProcessBuilder builder = new ProcessBuilder();
FileUtil.mkParentDirs(respPath);
String command = String.format("xtreme1_ctl --mode '%s' -src '%s' -out '%s' --rps '%s' --format=coco", type, srcPath, outPath, respPath);
String command = String.format("script_ctl --mode '%s' --src '%s' --dst '%s' --rps '%s' --fmt=coco", type, srcPath, outPath, respPath);
builder.command("sh", "-c", command);
Process process = builder.start();
BufferedReader in = new BufferedReader(new InputStreamReader(process.getErrorStream()));
Expand Down
1 change: 1 addition & 0 deletions frontend/image-tool/src/package/image-editor/utils/data.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ export function copyData(
updateTrans.transforms.push(copyedAttrs);
} else {
const newObject = annotate.cloneThisShape();
newObject.userData.backId = undefined;
newObject.userData.resultStatus = Const.Copied;
addOption.objects.push(newObject);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,7 @@ export default function useBottom() {
onMounted(() => {
editor.on(EditorEvent.CURRENT_TRACK_CHANGE, onSelect);
editor.on(EditorEvent.ANNOTATE_ADD, onUpdate);
// editor.playManager.on(EditorEvent.PLAY_STOP, onFrameStop);
PlayManager.instance.on(EditorEvent.PLAY_STOP, onFrameStop);
// editor.cmdManager.addEventListener(EditorEvent.UNDO, onUpdate);
// editor.cmdManager.addEventListener(EditorEvent.REDO, onUpdate);
editor.hotkeyManager.bindSeriesFrameEvent();
Expand All @@ -154,7 +154,7 @@ export default function useBottom() {
onBeforeUnmount(() => {
editor.off(EditorEvent.CURRENT_TRACK_CHANGE, onSelect);
editor.off(EditorEvent.ANNOTATE_ADD, onUpdate);
// editor.playManager.off(EditorEvent.PLAY_STOP, onFrameStop);
PlayManager.instance.off(EditorEvent.PLAY_STOP, onFrameStop);
// editor.cmdManager.removeEventListener(EditorEvent.UNDO, onUpdate);
// editor.cmdManager.removeEventListener(EditorEvent.REDO, onUpdate);
});
Expand Down
2 changes: 1 addition & 1 deletion frontend/pc-tool/src/components/Header/useHeader.ts
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,7 @@ export default function useHeader() {
bsState.submitting = true;
try {
if (isSeriesFrame) {
editor.saveObject(frames, true);
await editor.saveObject(frames, true);
await api.submitData(seriesFrameId ?? '');
// await updateDataStatus(frames);
unlockData();
Expand Down

0 comments on commit 357e930

Please sign in to comment.