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

DL models as serverless functions #1767

Merged
merged 133 commits into from
Jul 29, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
133 commits
Select commit Hold shift + click to select a range
583deca
Initial experiments with nuclio
Apr 21, 2020
f9c58e6
Update nuclio prototype
Apr 22, 2020
2920c5b
Improve nuclio prototype for dextr.
Apr 23, 2020
0fa76fb
Merge remote-tracking branch 'origin/develop' into nm/serverless
Apr 24, 2020
2a76d71
Dummy lambda manager
Apr 25, 2020
13978ec
OpenFaaS prototype (dextr.bin and dextr.xml are empty).
Apr 6, 2020
0cd4127
Moved openfaas prototype.
Apr 25, 2020
638ae73
Merge remote-tracking branch 'origin/develop' into nm/serverless
Apr 25, 2020
d089f49
Add comments
Apr 25, 2020
3481721
Add serializers and HLD for lambda_manager
Apr 26, 2020
096eb2d
Merge remote-tracking branch 'origin/develop' into nm/serverless
May 1, 2020
144f7be
Initial version of Mask RCNN (without debugging)
May 6, 2020
e85f4b7
Merge remote-tracking branch 'origin/develop' into nm/serverless
May 6, 2020
e0f3aea
Initial version for faster_rcnn_inception_v2_coco
May 9, 2020
af5dda4
Fix faster_rcnn_inception_v2_coco
May 9, 2020
6d061fc
Implemented mask_rcnn_inception_resnet_v2_atrous_coco
May 10, 2020
8dbfeb9
Implemented yolo detector as a lambda function
May 11, 2020
b9c7a86
Merge remote-tracking branch 'origin/develop' into nm/serverless
May 14, 2020
bb92b4a
Removed dextr app.
May 18, 2020
f9cfdf8
Merge remote-tracking branch 'origin/develop' into nm/serverless
May 18, 2020
fd06913
Added types for each function (detector and interactor)
May 18, 2020
985aa6d
Merge remote-tracking branch 'origin/develop' into nm/serverless
May 19, 2020
d79646a
Initial version of lambda_manager.
May 20, 2020
4ec9da9
Implement a couple of methods for lambda:
May 20, 2020
55aeb80
Merge remote-tracking branch 'origin/develop' into nm/serverless
May 28, 2020
5930d07
Merge remote-tracking branch 'origin/develop' into nm/serverless
May 29, 2020
666e71c
First working version of dextr serverless function
May 31, 2020
c160941
First version of dextr which works in UI.
May 31, 2020
86f9ab2
Modify omz.public.faster_rcnn_inception_v2_coco
Jun 1, 2020
b7c4768
Improve omz.public.mask_rcnn_inception_resnet_v2_atrous_coco
Jun 1, 2020
6b232d6
Improve omz.public.yolo-v3-tf function
Jun 1, 2020
737ccce
Implemented the initial version of requests for lambda manager.
Jun 1, 2020
be16027
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 10, 2020
3b44879
First working version of POST /api/v1/lambda/requests
Jun 11, 2020
67c3337
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 16, 2020
220d905
Updated specification of function.yaml (added labels and used annotat…
Jun 17, 2020
aea4665
Added health check for containers (nuclio dashboard feature)
Jun 17, 2020
5d1d775
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 17, 2020
30d4579
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 18, 2020
9490d1a
Read labels spec from function.yaml.
Jun 18, 2020
ed19ccf
Added settings for NUCLIO
Jun 18, 2020
393e631
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 18, 2020
b103703
Fixed a couple of typos. Now it works in most cases.
Jun 18, 2020
fc3d6c6
Remove Plugin REST API
Jun 19, 2020
ff6d89e
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 19, 2020
7a84e4c
Remove tf_annotation app (it will be replaced by serverless function)
Jun 19, 2020
093e4e7
Remove tf_annotation and cuda components
Jun 19, 2020
31858e9
Cleanup docs and Dockerfile from CUDA component.
Jun 19, 2020
88fed71
Just renamed directories inside serverless
Jun 19, 2020
38fd4e3
Remove redundant files and code
Jun 19, 2020
a396822
Remove redundant files.
Jun 19, 2020
b04407e
Remove outdated files
Jun 19, 2020
f518ba8
Remove outdated code
Jun 19, 2020
d0b5cfb
Delete reid app and add draft of serverless function for reid.
Jun 20, 2020
66711b8
Model list in UI.
Jun 21, 2020
92463af
Fixed the framework name (got it from lambda function).
Jun 21, 2020
54f64e9
Add maxRequestBodySize for functions, remove redundant code from UI f…
Jun 22, 2020
fa89f96
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 22, 2020
e136827
Update view of models page.
Jun 22, 2020
61d20ca
Unblock mapping for "primary" models.
Jun 23, 2020
5317e62
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 23, 2020
cfaf97f
Implement cleanup flag for lambda/requests and labeling mapping for f…
Jun 23, 2020
461a4de
Implement protection from running multiple jobs for the same task.
Jun 23, 2020
459aeaa
Fix invocation of functions in docker container.
Jun 24, 2020
fd6ba2f
Fix Dockerfile.ci
Jun 25, 2020
e14705e
Remove unused files from lambda_manager
Jun 25, 2020
32d4c59
Fix codacy warnings
Jun 25, 2020
c8b26f9
Fix codacy issues.
Jun 26, 2020
102a4e3
Fix codacy warnings
Jun 26, 2020
3652922
Implement progress and cancel (aka delete) operation.
Jun 26, 2020
3c43b9d
Send annotations in batch.
Jun 26, 2020
793b661
Fix UI. Now it can retrieve information about inference requests in p…
Jun 26, 2020
4528763
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 26, 2020
b839fd5
Update CHANGELOG.md
Jun 26, 2020
c6dae22
Update cvat-ui version.
Jun 26, 2020
aa53394
Update nuclio version.
Jun 26, 2020
039b872
Implement serverless/tensorflow/faster_rcnn_inception_v2_coco
Jun 28, 2020
b3d9cac
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 29, 2020
e41f65c
Add information how to install nuclio platform and run serverless fun…
Jun 30, 2020
6a23ccf
Add installation instructions for serverless functions.
Jun 30, 2020
573e3d1
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jun 30, 2020
39fe337
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 1, 2020
f7e12b0
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 1, 2020
8c47af7
Update OpenVINO files which are responsible for loading network
Jul 3, 2020
d982a18
relocated functions
Jul 3, 2020
7722ffd
Update dextr function.
Jul 3, 2020
2ab1030
Update faster_rcnn function from omz
Jul 3, 2020
3622e81
Fix OpenVINO Mask-RCNN
Jul 4, 2020
89165cd
Fix YOLO v3 serverless function.
Jul 4, 2020
6906b63
Dummy serverless functions for a couple of more OpenVINO models.
Jul 5, 2020
38004a1
Protected lambda manager views by correct permissions.
Jul 6, 2020
ecb8a72
Fix name of Faster RCNN from Tensorflow.
Jul 6, 2020
9b0faf6
Implement Mask RCNN via Tensorflow serverless function.
Jul 8, 2020
b4bc20f
Minor client changes (#1847)
bsekachev Jul 8, 2020
11dc24b
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 9, 2020
a072105
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 13, 2020
aba0f84
Merge branch 'nm/serverless' of https://github.com/opencv/cvat into n…
Jul 13, 2020
bd70a0b
Add reid serverless function (no support in lambda manager).
Jul 14, 2020
e95660c
Fix contribution guide.
Jul 14, 2020
a8cca9c
Fix person-reidentification-retail-300 and implement text-detection-0004
Jul 14, 2020
5fdedd3
Add semantic-segmentation-adas-0001
Jul 14, 2020
e2bd562
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 14, 2020
34f48ce
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 15, 2020
e7501b1
Moving model management to cvat-core (#1905)
bsekachev Jul 15, 2020
7e78ccb
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 16, 2020
aee568b
Remove duplicated files for OpenVINO serverless functions.
Jul 17, 2020
889365f
Updated CHANGELOG.md
Jul 17, 2020
e26f47e
Remove outdated code.
Jul 17, 2020
90f8e13
Running dextr via lambda manager (#1912)
bsekachev Jul 17, 2020
fcb5790
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 19, 2020
f36df30
Deleted outdated migration.
Jul 19, 2020
98e5398
Add name for DEXTR function.
Jul 20, 2020
6461b10
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 20, 2020
52b1f4d
Fix restart policy for serverless functions.
Jul 20, 2020
44b5d01
Fix openvino serverless functions for images with alpha channel
Jul 20, 2020
1525ce2
Add more tensorflow serverless functions into deploy.sh
Jul 21, 2020
be8d06c
Use ID instead of name for DEXTR (#1926)
bsekachev Jul 22, 2020
0684cae
Update DEXTR function
Jul 24, 2020
e5b8f2a
Merge branch 'nm/serverless' of https://github.com/opencv/cvat into n…
Jul 24, 2020
5352a94
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 24, 2020
a1096a1
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 24, 2020
2ff7395
Added source "auto" inside lambda manager for automatic annotation.
Jul 24, 2020
2bad1de
Customize payload (depends on type of lambda function).
Jul 24, 2020
8f60d54
First working version of REID (Server only).
Jul 25, 2020
05762ad
Fix codacy warnings
Jul 25, 2020
0c6e033
Avoid exception during migration (workaround)
Jul 25, 2020
1973a07
Add siammask serverless function (it doesn't work, need to serialize …
Jul 27, 2020
d32201e
Run ReID from UI (#1949)
bsekachev Jul 28, 2020
44df570
Merge branch 'develop' into nm/serverless
nmanovic Jul 28, 2020
cc081bd
Merge remote-tracking branch 'origin/develop' into nm/serverless
Jul 29, 2020
ced2746
Removed reid route in installation.md
Jul 29, 2020
4210645
Fix a command to get lena image in CONTRIBUTION guide.
Jul 29, 2020
6dcb354
Fix typo and crash in case a polygon is a line.
Jul 29, 2020
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
Prev Previous commit
Next Next commit
Merge remote-tracking branch 'origin/develop' into nm/serverless
  • Loading branch information
Nikita Manovich committed Jul 24, 2020
commit a1096a1ec0fa606f51482b2290db45cffe7bb281
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
## [1.1.0-beta] - Unreleased
### Added
- DL models as serverless functions (<https://github.com/opencv/cvat/pull/1767>)
- Source type support for tags, shapes and tracks (<https://github.com/opencv/cvat/pull/1192>)
- Source type support for CVAT Dumper/Loader (<https://github.com/opencv/cvat/pull/1192>)

### Changed
- Smaller object details (<https://github.com/opencv/cvat/pull/1877>)
Expand Down
6 changes: 3 additions & 3 deletions cvat-canvas/src/typescript/canvasView.ts
Original file line number Diff line number Diff line change
Expand Up @@ -189,7 +189,7 @@ export class CanvasViewImpl implements CanvasView, Listener {
}

private onEditDone(state: any, points: number[]): void {
if (state && points) {
if (state && points) {
const event: CustomEvent = new CustomEvent('canvas.edited', {
bubbles: false,
cancelable: true,
Expand Down Expand Up @@ -1732,14 +1732,14 @@ export class CanvasViewImpl implements CanvasView, Listener {

private addText(state: any): SVG.Text {
const { undefinedAttrValue } = this.configuration;
const { label, clientID, attributes } = state;
const { label, clientID, attributes, source } = state;
const attrNames = label.attributes.reduce((acc: any, val: any): void => {
acc[val.id] = val.name;
return acc;
}, {});

return this.adoptedText.text((block): void => {
block.tspan(`${label.name} ${clientID}`).style('text-transform', 'uppercase');
block.tspan(`${label.name} ${clientID} (${source})`).style('text-transform', 'uppercase');
for (const attrID of Object.keys(attributes)) {
const value = attributes[attrID] === undefinedAttrValue
? '' : attributes[attrID];
Expand Down
3 changes: 3 additions & 0 deletions cvat-core/src/annotations-collection.js
Original file line number Diff line number Diff line change
Expand Up @@ -402,6 +402,7 @@
frame: Math.min.apply(null, Object.keys(keyframes).map((frame) => +frame)),
shapes: Object.values(keyframes),
group: 0,
source: objectStates[0].source,
label_id: label.id,
attributes: Object.keys(objectStates[0].attributes)
.reduce((accumulator, attrID) => {
Expand Down Expand Up @@ -763,13 +764,15 @@
points: [...state.points],
type: state.shapeType,
z_order: state.zOrder,
source: state.source,
});
} else if (state.objectType === 'track') {
constructed.tracks.push({
attributes: attributes
.filter((attr) => !labelAttributes[attr.spec_id].mutable),
frame: state.frame,
group: 0,
source: state.source,
label_id: state.label.id,
shapes: [{
attributes: attributes
Expand Down
42 changes: 41 additions & 1 deletion cvat-core/src/annotations-objects.js
Original file line number Diff line number Diff line change
Expand Up @@ -183,6 +183,7 @@
this.removed = false;
this.lock = false;
this.color = color;
this.source = data.source;
this.updated = Date.now();
this.attributes = data.attributes.reduce((attributeAccumulator, attr) => {
attributeAccumulator[attr.spec_id] = attr.value;
Expand Down Expand Up @@ -295,6 +296,21 @@
}, [this.clientID], frame);
}

_saveSource(source, frame) {
const undoSource = this.source;
const redoSource = source;

this.history.do(HistoryActions.CHANGED_SOURCE, () => {
this.source = undoSource;
this.updated = Date.now();
}, () => {
this.source = redoSource;
this.updated = Date.now();
}, [this.clientID], frame);

this.source = source;
}

_validateStateBeforeSave(frame, data, updated) {
let fittedPoints = [];

Expand Down Expand Up @@ -381,6 +397,10 @@
}
}

if (updated.source) {
checkObjectType('source', data.source, 'string', null);
}

return fittedPoints;
}

Expand All @@ -396,7 +416,8 @@
updateTimestamp(updated) {
const anyChanges = updated.label || updated.attributes || updated.points
|| updated.outside || updated.occluded || updated.keyframe
|| updated.zOrder || updated.hidden || updated.lock || updated.pinned;
|| updated.zOrder || updated.hidden || updated.lock || updated.pinned
|| updated.source;

if (anyChanges) {
this.updated = Date.now();
Expand Down Expand Up @@ -492,6 +513,7 @@
frame: this.frame,
label_id: this.label.id,
group: this.group,
source: this.source,
};
}

Expand Down Expand Up @@ -520,6 +542,7 @@
updated: this.updated,
pinned: this.pinned,
frame,
source: this.source,
};
}

Expand Down Expand Up @@ -619,6 +642,10 @@
this._saveHidden(data.hidden, frame);
}

if (updated.source) {
this._saveSource(data.source, frame);
}

this.updateTimestamp(updated);
updated.reset();

Expand Down Expand Up @@ -659,6 +686,7 @@
frame: this.frame,
label_id: this.label.id,
group: this.group,
source: this.source,
attributes: Object.keys(this.attributes).reduce((attributeAccumulator, attrId) => {
if (!labelAttributes[attrId].mutable) {
attributeAccumulator.push({
Expand Down Expand Up @@ -726,6 +754,7 @@
last,
},
frame,
source: this.source,
};
}

Expand Down Expand Up @@ -1034,6 +1063,7 @@
outside: current.outside,
occluded: current.occluded,
attributes: {},
source: current.source,
} : undefined;

if (redoShape) {
Expand Down Expand Up @@ -1098,6 +1128,10 @@
this._saveAttributes(data.attributes, frame);
}

if (updated.source) {
this._saveSource(data.source, frame);
}

if (updated.keyframe) {
this._saveKeyframe(frame, data.keyframe);
}
Expand Down Expand Up @@ -1164,6 +1198,7 @@
frame: this.frame,
label_id: this.label.id,
group: this.group,
source: this.source,
attributes: Object.keys(this.attributes).reduce((attributeAccumulator, attrId) => {
attributeAccumulator.push({
spec_id: attrId,
Expand Down Expand Up @@ -1194,6 +1229,7 @@
color: this.color,
updated: this.updated,
frame,
source: this.source,
};
}

Expand Down Expand Up @@ -1228,6 +1264,10 @@
this._saveColor(data.color, frame);
}

if (updated.source) {
this._saveSource(data.source, frame);
}

this.updateTimestamp(updated);
updated.reset();

Expand Down
2 changes: 1 addition & 1 deletion cvat-core/src/annotations-saver.js
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@

const keys = ['id', 'label_id', 'group', 'frame',
'occluded', 'z_order', 'points', 'type', 'shapes',
'attributes', 'value', 'spec_id', 'outside'];
'attributes', 'value', 'spec_id', 'source', 'outside'];

// Find created and updated objects
for (const type of Object.keys(exported)) {
Expand Down
2 changes: 2 additions & 0 deletions cvat-core/src/api.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ function build() {
HistoryActions,
RQStatus,
colors,
source,
} = require('./enums');

const {
Expand Down Expand Up @@ -655,6 +656,7 @@ function build() {
HistoryActions,
RQStatus,
colors,
source,
},
/**
* Namespace is used for access to exceptions
Expand Down
17 changes: 17 additions & 0 deletions cvat-core/src/enums.js
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,20 @@
CUBOID: 'cuboid',
});

/**
* Annotation type
* @enum {string}
* @name source
* @memberof module:API.cvat.enums
* @property {string} MANUAL 'manual'
* @property {string} AUTO 'auto'
* @readonly
*/
const source = Object.freeze({
MANUAL:'manual',
AUTO:'auto',
});

/**
* Logger event types
* @enum {string}
Expand Down Expand Up @@ -210,6 +224,7 @@
* @property {string} CHANGED_LOCK Changed lock
* @property {string} CHANGED_COLOR Changed color
* @property {string} CHANGED_HIDDEN Changed hidden
* @property {string} CHANGED_SOURCE Changed source
* @property {string} MERGED_OBJECTS Merged objects
* @property {string} SPLITTED_TRACK Splitted track
* @property {string} GROUPED_OBJECTS Grouped objects
Expand All @@ -229,6 +244,7 @@
CHANGED_PINNED: 'Changed pinned',
CHANGED_COLOR: 'Changed color',
CHANGED_HIDDEN: 'Changed hidden',
CHANGED_SOURCE: 'Changed source',
MERGED_OBJECTS: 'Merged objects',
SPLITTED_TRACK: 'Splitted track',
GROUPED_OBJECTS: 'Grouped objects',
Expand Down Expand Up @@ -275,5 +291,6 @@
HistoryActions,
RQStatus,
colors,
source,
};
})();
19 changes: 18 additions & 1 deletion cvat-core/src/object-state.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
* </br> Necessary fields: objectType, shapeType, frame, updated, group
* </br> Optional fields: keyframes, clientID, serverID
* </br> Optional fields which can be set later: points, zOrder, outside,
* occluded, hidden, attributes, lock, label, color, keyframe
* occluded, hidden, attributes, lock, label, color, keyframe, source
*/
constructor(serialized) {
const data = {
Expand All @@ -39,6 +39,7 @@
color: null,
hidden: null,
pinned: null,
source: null,
keyframes: serialized.keyframes,
group: serialized.group,
updated: serialized.updated,
Expand Down Expand Up @@ -68,6 +69,7 @@
this.lock = false;
this.color = false;
this.hidden = false;
this.source = false;

return reset;
},
Expand Down Expand Up @@ -109,6 +111,20 @@
*/
get: () => data.shapeType,
},
source: {
/**
* @name source
* @type {module:API.cvat.enums.source}
* @memberof module:API.cvat.classes.ObjectState
* @readonly
* @instance
*/
get: () => data.source,
set: (source) => {
data.updateFlags.source = true;
data.source = source;
},
},
clientID: {
/**
* @name clientID
Expand Down Expand Up @@ -343,6 +359,7 @@

this.label = serialized.label;
this.lock = serialized.lock;
this.source = serialized.source;

if (typeof (serialized.zOrder) === 'number') {
this.zOrder = serialized.zOrder;
Expand Down
1 change: 1 addition & 0 deletions cvat-ui/src/actions/annotation-actions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -485,6 +485,7 @@ export function propagateObjectAsync(
label: objectState.label,
zOrder: objectState.zOrder,
frame: from,
source: objectState.source,
};

await sessionInstance.logger.log(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -324,6 +324,7 @@ export default class CanvasWrapperComponent extends React.PureComponent<Props> {
.filter((label: any) => label.id === activeLabelID)[0];
state.occluded = state.occluded || false;
state.frame = frame;
state.source = 'manual';
const objectState = new cvat.classes.ObjectState(state);
onCreateAnnotations(jobInstance, frame, [objectState]);
};
Expand Down Expand Up @@ -500,6 +501,7 @@ export default class CanvasWrapperComponent extends React.PureComponent<Props> {
points,
} = event.detail;
state.points = points;
state.source = 'manual';
onUpdateAnnotations([state]);
};

Expand Down
Loading
You are viewing a condensed version of this merge commit. You can view the full changes here.