Compare commits
	
		
			73 Commits
		
	
	
		
			a030a0ef16
			...
			kat/add-da
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 890bea2571 | |||
| f57f6dc32d | |||
| 14863e3357 | |||
| 
						 | 
					58f01c567c | ||
| 937368c753 | |||
| d8c11875d4 | |||
| bacd9e77f0 | |||
| 69d755ba32 | |||
| 31fb95e3b0 | |||
| 7d0f9870dd | |||
| 4a493b4e8d | |||
| 341dc819a0 | |||
| b58aecf7a5 | |||
| 301c017d5e | |||
| 1a4b676635 | |||
| ce54bef0b4 | |||
| 2699d29d7b | |||
| 63a07d58ca | |||
| 59fe332fe0 | |||
| 33723f4ea2 | |||
| c0ee55069e | |||
| 492ae4a225 | |||
| dcdb324391 | |||
| 90685cfdbf | |||
| ab61894373 | |||
| 662e0ade64 | |||
| 75aa847ae1 | |||
| c013228f79 | |||
| 740daf95ae | |||
| 768d29f93e | |||
| 837e084a5a | |||
| caea1b9572 | |||
| 0a255f161a | |||
| 85a2da4b5c | |||
| 647ef3049b | |||
| 7b48a5b6e2 | |||
| ec2e3da513 | |||
| 72729e410b | |||
| 5a9205a9b8 | |||
| a33601158f | |||
| 3c6b37b567 | |||
| 9b18ada78d | |||
| d57bb607e4 | |||
| 1f88ee4a0c | |||
| a32317e72f | |||
| b60cbe3854 | |||
| e0b150aa2a | |||
| 2bdfcb994e | |||
| d5c6014548 | |||
| de6fcacfd0 | |||
| 
						 | 
					993f62b6cf | ||
| aabd74d7d7 | |||
| 15b307a88f | |||
| 72b338bfc2 | |||
| 267486774c | |||
| b94a568ef1 | |||
| b773ccfc8f | |||
| fd5c28e073 | |||
| 4c232829b6 | |||
| ddf1036009 | |||
| 9b3e5c23a0 | |||
| a7eae9d46b | |||
| 8c3e9d6273 | |||
| f306cc6c16 | |||
| 643cdb29e3 | |||
| 89287a0100 | |||
| f9b02f65e0 | |||
| 41169e2848 | |||
| ba36bc709c | |||
| 4005416233 | |||
| db4a6315cd | |||
| af38fdea64 | |||
| 172df69340 | 
@@ -13,13 +13,15 @@ _sym_db = _symbol_database.Default()
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\nshot.proto\x12\x0fserialized_shot\"?\n\x03\x42ox\x12\x0c\n\x04left\x18\x01 \x01(\x02\x12\x0b\n\x03top\x18\x02 \x01(\x02\x12\r\n\x05width\x18\x03 \x01(\x02\x12\x0e\n\x06height\x18\x04 \x01(\x02\"\x1d\n\x05Point\x12\t\n\x01x\x18\x01 \x01(\x02\x12\t\n\x01y\x18\x02 \x01(\x02\"\x7f\n\rBallDetection\x12.\n\x0eplane_position\x18\x01 \x01(\x0b\x32\x16.serialized_shot.Point\x12(\n\nannotation\x18\x02 \x01(\x0b\x32\x14.serialized_shot.Box\x12\x14\n\x0cinterpolated\x18\x03 \x01(\x08\"T\n\x10RLEBallDetection\x12\x31\n\tdetection\x18\x01 \x01(\x0b\x32\x1e.serialized_shot.BallDetection\x12\r\n\x05\x63ount\x18\x02 \x01(\r\"L\n\x13RLEDetectionHistory\x12\x35\n\ndetections\x18\x01 \x03(\x0b\x32!.serialized_shot.RLEBallDetection\"F\n\x10\x44\x65tectionHistory\x12\x32\n\ndetections\x18\x01 \x03(\x0b\x32\x1e.serialized_shot.BallDetection\"\xe6\x01\n\x04Path\x12\x13\n\x0bstart_frame\x18\x01 \x01(\r\x12\x11\n\tend_frame\x18\x02 \x01(\r\x12\x37\n\ndetections\x18\x03 \x01(\x0b\x32!.serialized_shot.DetectionHistoryH\x00\x12>\n\x0erle_detections\x18\x04 \x01(\x0b\x32$.serialized_shot.RLEDetectionHistoryH\x00\x12\x15\n\x0bnot_present\x18\x05 \x01(\x08H\x00\x12\x11\n\tis_static\x18\x06 \x01(\x08\x42\x13\n\x11\x64\x65tection_history\"R\n\x11IdentifierHistory\x12\x17\n\x0f\x62\x61ll_identifier\x18\x01 \x01(\r\x12$\n\x05paths\x18\x02 \x03(\x0b\x32\x15.serialized_shot.Path\"H\n\x04Shot\x12@\n\x14identifier_histories\x18\x03 \x03(\x0b\x32\".serialized_shot.IdentifierHistoryb\x06proto3')
 | 
			
		||||
DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\nshot.proto\x12\x0fserialized_shot\"?\n\x03\x42ox\x12\x0c\n\x04left\x18\x01 \x01(\x02\x12\x0b\n\x03top\x18\x02 \x01(\x02\x12\r\n\x05width\x18\x03 \x01(\x02\x12\x0e\n\x06height\x18\x04 \x01(\x02\"\x1d\n\x05Point\x12\t\n\x01x\x18\x01 \x01(\x02\x12\t\n\x01y\x18\x02 \x01(\x02\"\x7f\n\rBallDetection\x12.\n\x0eplane_position\x18\x01 \x01(\x0b\x32\x16.serialized_shot.Point\x12(\n\nannotation\x18\x02 \x01(\x0b\x32\x14.serialized_shot.Box\x12\x14\n\x0cinterpolated\x18\x03 \x01(\x08\"T\n\x10RLEBallDetection\x12\x31\n\tdetection\x18\x01 \x01(\x0b\x32\x1e.serialized_shot.BallDetection\x12\r\n\x05\x63ount\x18\x02 \x01(\r\"L\n\x13RLEDetectionHistory\x12\x35\n\ndetections\x18\x01 \x03(\x0b\x32!.serialized_shot.RLEBallDetection\"F\n\x10\x44\x65tectionHistory\x12\x32\n\ndetections\x18\x01 \x03(\x0b\x32\x1e.serialized_shot.BallDetection\"\xfc\x01\n\rCollisionInfo\x12\x0e\n\x06source\x18\x01 \x01(\r\x12M\n\x10\x62\x61ll_identifiers\x18\x02 \x03(\x0b\x32\x33.serialized_shot.CollisionInfo.BallIdentifiersEntry\x12\x17\n\x0fwall_identifier\x18\x03 \x01(\r\x12\x13\n\x0b\x66rame_index\x18\x04 \x01(\r\x12\x0e\n\x06static\x18\x05 \x01(\x08\x1aN\n\x14\x42\x61llIdentifiersEntry\x12\x0b\n\x03key\x18\x01 \x01(\r\x12%\n\x05value\x18\x02 \x01(\x0b\x32\x16.serialized_shot.Point:\x02\x38\x01\"\xcc\x02\n\x04Path\x12\x13\n\x0bstart_frame\x18\x01 \x01(\r\x12\x11\n\tend_frame\x18\x02 \x01(\r\x12\x37\n\ndetections\x18\x03 \x01(\x0b\x32!.serialized_shot.DetectionHistoryH\x00\x12>\n\x0erle_detections\x18\x04 \x01(\x0b\x32$.serialized_shot.RLEDetectionHistoryH\x00\x12\x15\n\x0bnot_present\x18\x05 \x01(\x08H\x00\x12\x11\n\tis_static\x18\x06 \x01(\x08\x12\x32\n\nstart_info\x18\x07 \x01(\x0b\x32\x1e.serialized_shot.CollisionInfo\x12\x30\n\x08\x65nd_info\x18\x08 \x01(\x0b\x32\x1e.serialized_shot.CollisionInfoB\x13\n\x11\x64\x65tection_history\"R\n\x11IdentifierHistory\x12\x17\n\x0f\x62\x61ll_identifier\x18\x01 \x01(\r\x12$\n\x05paths\x18\x02 \x03(\x0b\x32\x15.serialized_shot.Path\"\xf4\x01\n\x12KeyBallIdentifiers\x12\x10\n\x08\x63ue_ball\x18\x01 \x01(\r\x12\x13\n\x0bobject_ball\x18\x02 \x01(\r\x12\x13\n\x0btarget_ball\x18\x03 \x01(\r\x12\x18\n\x10\x63ontact_sequence\x18\x04 \x03(\r\x12\x18\n\x0b\x63ue_ball_id\x18\x05 \x01(\rH\x00\x88\x01\x01\x12\x1b\n\x0eobject_ball_id\x18\x06 \x01(\rH\x01\x88\x01\x01\x12\x1b\n\x0etarget_ball_id\x18\x07 \x01(\rH\x02\x88\x01\x01\x42\x0e\n\x0c_cue_ball_idB\x11\n\x0f_object_ball_idB\x11\n\x0f_target_ball_id\"\xa8\x01\n\x04Shot\x12@\n\x14identifier_histories\x18\x03 \x03(\x0b\x32\".serialized_shot.IdentifierHistory\x12\x36\n\tkey_balls\x18\x04 \x01(\x0b\x32#.serialized_shot.KeyBallIdentifiers\x12\x13\n\x0bstart_index\x18\x05 \x01(\r\x12\x11\n\tend_index\x18\x06 \x01(\rb\x06proto3')
 | 
			
		||||
 | 
			
		||||
_globals = globals()
 | 
			
		||||
_builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
 | 
			
		||||
_builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'shot_pb2', _globals)
 | 
			
		||||
if _descriptor._USE_C_DESCRIPTORS == False:
 | 
			
		||||
  DESCRIPTOR._options = None
 | 
			
		||||
  _globals['_COLLISIONINFO_BALLIDENTIFIERSENTRY']._options = None
 | 
			
		||||
  _globals['_COLLISIONINFO_BALLIDENTIFIERSENTRY']._serialized_options = b'8\001'
 | 
			
		||||
  _globals['_BOX']._serialized_start=31
 | 
			
		||||
  _globals['_BOX']._serialized_end=94
 | 
			
		||||
  _globals['_POINT']._serialized_start=96
 | 
			
		||||
@@ -32,10 +34,16 @@ if _descriptor._USE_C_DESCRIPTORS == False:
 | 
			
		||||
  _globals['_RLEDETECTIONHISTORY']._serialized_end=418
 | 
			
		||||
  _globals['_DETECTIONHISTORY']._serialized_start=420
 | 
			
		||||
  _globals['_DETECTIONHISTORY']._serialized_end=490
 | 
			
		||||
  _globals['_PATH']._serialized_start=493
 | 
			
		||||
  _globals['_PATH']._serialized_end=723
 | 
			
		||||
  _globals['_IDENTIFIERHISTORY']._serialized_start=725
 | 
			
		||||
  _globals['_IDENTIFIERHISTORY']._serialized_end=807
 | 
			
		||||
  _globals['_SHOT']._serialized_start=809
 | 
			
		||||
  _globals['_SHOT']._serialized_end=881
 | 
			
		||||
  _globals['_COLLISIONINFO']._serialized_start=493
 | 
			
		||||
  _globals['_COLLISIONINFO']._serialized_end=745
 | 
			
		||||
  _globals['_COLLISIONINFO_BALLIDENTIFIERSENTRY']._serialized_start=667
 | 
			
		||||
  _globals['_COLLISIONINFO_BALLIDENTIFIERSENTRY']._serialized_end=745
 | 
			
		||||
  _globals['_PATH']._serialized_start=748
 | 
			
		||||
  _globals['_PATH']._serialized_end=1080
 | 
			
		||||
  _globals['_IDENTIFIERHISTORY']._serialized_start=1082
 | 
			
		||||
  _globals['_IDENTIFIERHISTORY']._serialized_end=1164
 | 
			
		||||
  _globals['_KEYBALLIDENTIFIERS']._serialized_start=1167
 | 
			
		||||
  _globals['_KEYBALLIDENTIFIERS']._serialized_end=1411
 | 
			
		||||
  _globals['_SHOT']._serialized_start=1414
 | 
			
		||||
  _globals['_SHOT']._serialized_end=1582
 | 
			
		||||
# @@protoc_insertion_point(module_scope)
 | 
			
		||||
 
 | 
			
		||||
@@ -55,21 +55,46 @@ class DetectionHistory(_message.Message):
 | 
			
		||||
    detections: _containers.RepeatedCompositeFieldContainer[BallDetection]
 | 
			
		||||
    def __init__(self, detections: _Optional[_Iterable[_Union[BallDetection, _Mapping]]] = ...) -> None: ...
 | 
			
		||||
 | 
			
		||||
class CollisionInfo(_message.Message):
 | 
			
		||||
    __slots__ = ["source", "ball_identifiers", "wall_identifier", "frame_index", "static"]
 | 
			
		||||
    class BallIdentifiersEntry(_message.Message):
 | 
			
		||||
        __slots__ = ["key", "value"]
 | 
			
		||||
        KEY_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
        VALUE_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
        key: int
 | 
			
		||||
        value: Point
 | 
			
		||||
        def __init__(self, key: _Optional[int] = ..., value: _Optional[_Union[Point, _Mapping]] = ...) -> None: ...
 | 
			
		||||
    SOURCE_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    BALL_IDENTIFIERS_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    WALL_IDENTIFIER_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    FRAME_INDEX_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    STATIC_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    source: int
 | 
			
		||||
    ball_identifiers: _containers.MessageMap[int, Point]
 | 
			
		||||
    wall_identifier: int
 | 
			
		||||
    frame_index: int
 | 
			
		||||
    static: bool
 | 
			
		||||
    def __init__(self, source: _Optional[int] = ..., ball_identifiers: _Optional[_Mapping[int, Point]] = ..., wall_identifier: _Optional[int] = ..., frame_index: _Optional[int] = ..., static: bool = ...) -> None: ...
 | 
			
		||||
 | 
			
		||||
class Path(_message.Message):
 | 
			
		||||
    __slots__ = ["start_frame", "end_frame", "detections", "rle_detections", "not_present", "is_static"]
 | 
			
		||||
    __slots__ = ["start_frame", "end_frame", "detections", "rle_detections", "not_present", "is_static", "start_info", "end_info"]
 | 
			
		||||
    START_FRAME_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    END_FRAME_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    DETECTIONS_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    RLE_DETECTIONS_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    NOT_PRESENT_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    IS_STATIC_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    START_INFO_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    END_INFO_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    start_frame: int
 | 
			
		||||
    end_frame: int
 | 
			
		||||
    detections: DetectionHistory
 | 
			
		||||
    rle_detections: RLEDetectionHistory
 | 
			
		||||
    not_present: bool
 | 
			
		||||
    is_static: bool
 | 
			
		||||
    def __init__(self, start_frame: _Optional[int] = ..., end_frame: _Optional[int] = ..., detections: _Optional[_Union[DetectionHistory, _Mapping]] = ..., rle_detections: _Optional[_Union[RLEDetectionHistory, _Mapping]] = ..., not_present: bool = ..., is_static: bool = ...) -> None: ...
 | 
			
		||||
    start_info: CollisionInfo
 | 
			
		||||
    end_info: CollisionInfo
 | 
			
		||||
    def __init__(self, start_frame: _Optional[int] = ..., end_frame: _Optional[int] = ..., detections: _Optional[_Union[DetectionHistory, _Mapping]] = ..., rle_detections: _Optional[_Union[RLEDetectionHistory, _Mapping]] = ..., not_present: bool = ..., is_static: bool = ..., start_info: _Optional[_Union[CollisionInfo, _Mapping]] = ..., end_info: _Optional[_Union[CollisionInfo, _Mapping]] = ...) -> None: ...
 | 
			
		||||
 | 
			
		||||
class IdentifierHistory(_message.Message):
 | 
			
		||||
    __slots__ = ["ball_identifier", "paths"]
 | 
			
		||||
@@ -79,8 +104,32 @@ class IdentifierHistory(_message.Message):
 | 
			
		||||
    paths: _containers.RepeatedCompositeFieldContainer[Path]
 | 
			
		||||
    def __init__(self, ball_identifier: _Optional[int] = ..., paths: _Optional[_Iterable[_Union[Path, _Mapping]]] = ...) -> None: ...
 | 
			
		||||
 | 
			
		||||
class KeyBallIdentifiers(_message.Message):
 | 
			
		||||
    __slots__ = ["cue_ball", "object_ball", "target_ball", "contact_sequence", "cue_ball_id", "object_ball_id", "target_ball_id"]
 | 
			
		||||
    CUE_BALL_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    OBJECT_BALL_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    TARGET_BALL_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    CONTACT_SEQUENCE_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    CUE_BALL_ID_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    OBJECT_BALL_ID_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    TARGET_BALL_ID_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    cue_ball: int
 | 
			
		||||
    object_ball: int
 | 
			
		||||
    target_ball: int
 | 
			
		||||
    contact_sequence: _containers.RepeatedScalarFieldContainer[int]
 | 
			
		||||
    cue_ball_id: int
 | 
			
		||||
    object_ball_id: int
 | 
			
		||||
    target_ball_id: int
 | 
			
		||||
    def __init__(self, cue_ball: _Optional[int] = ..., object_ball: _Optional[int] = ..., target_ball: _Optional[int] = ..., contact_sequence: _Optional[_Iterable[int]] = ..., cue_ball_id: _Optional[int] = ..., object_ball_id: _Optional[int] = ..., target_ball_id: _Optional[int] = ...) -> None: ...
 | 
			
		||||
 | 
			
		||||
class Shot(_message.Message):
 | 
			
		||||
    __slots__ = ["identifier_histories"]
 | 
			
		||||
    __slots__ = ["identifier_histories", "key_balls", "start_index", "end_index"]
 | 
			
		||||
    IDENTIFIER_HISTORIES_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    KEY_BALLS_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    START_INDEX_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    END_INDEX_FIELD_NUMBER: _ClassVar[int]
 | 
			
		||||
    identifier_histories: _containers.RepeatedCompositeFieldContainer[IdentifierHistory]
 | 
			
		||||
    def __init__(self, identifier_histories: _Optional[_Iterable[_Union[IdentifierHistory, _Mapping]]] = ...) -> None: ...
 | 
			
		||||
    key_balls: KeyBallIdentifiers
 | 
			
		||||
    start_index: int
 | 
			
		||||
    end_index: int
 | 
			
		||||
    def __init__(self, identifier_histories: _Optional[_Iterable[_Union[IdentifierHistory, _Mapping]]] = ..., key_balls: _Optional[_Union[KeyBallIdentifiers, _Mapping]] = ..., start_index: _Optional[int] = ..., end_index: _Optional[int] = ...) -> None: ...
 | 
			
		||||
 
 | 
			
		||||
@@ -3,10 +3,10 @@ syntax = "proto3";
 | 
			
		||||
package serialized_shot;
 | 
			
		||||
 | 
			
		||||
message Box {
 | 
			
		||||
	float left = 1;
 | 
			
		||||
	float top = 2;
 | 
			
		||||
	float width = 3;
 | 
			
		||||
	float height = 4;
 | 
			
		||||
  float left = 1;
 | 
			
		||||
  float top = 2;
 | 
			
		||||
  float width = 3;
 | 
			
		||||
  float height = 4;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message Point {
 | 
			
		||||
@@ -15,40 +15,63 @@ message Point {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message BallDetection {
 | 
			
		||||
	Point plane_position = 1;
 | 
			
		||||
	Box annotation = 2;
 | 
			
		||||
	bool interpolated = 3;
 | 
			
		||||
  Point plane_position = 1;
 | 
			
		||||
  Box annotation = 2;
 | 
			
		||||
  bool interpolated = 3;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message RLEBallDetection {
 | 
			
		||||
	BallDetection detection = 1;
 | 
			
		||||
	uint32 count = 2;
 | 
			
		||||
  BallDetection detection = 1;
 | 
			
		||||
  uint32 count = 2;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message RLEDetectionHistory {
 | 
			
		||||
  repeated RLEBallDetection detections = 1;
 | 
			
		||||
}
 | 
			
		||||
message RLEDetectionHistory { repeated RLEBallDetection detections = 1; }
 | 
			
		||||
 | 
			
		||||
message DetectionHistory {
 | 
			
		||||
  repeated BallDetection detections = 1;
 | 
			
		||||
message DetectionHistory { repeated BallDetection detections = 1; }
 | 
			
		||||
 | 
			
		||||
message CollisionInfo {
 | 
			
		||||
  uint32 source = 1;
 | 
			
		||||
  map<uint32, Point> ball_identifiers = 2;
 | 
			
		||||
  uint32 wall_identifier = 3;
 | 
			
		||||
  uint32 frame_index = 4;
 | 
			
		||||
  bool static = 5;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message Path {
 | 
			
		||||
  uint32 start_frame = 1;
 | 
			
		||||
  uint32 end_frame = 2;
 | 
			
		||||
  oneof detection_history {
 | 
			
		||||
	DetectionHistory detections = 3;
 | 
			
		||||
	RLEDetectionHistory rle_detections = 4;
 | 
			
		||||
	bool not_present = 5;
 | 
			
		||||
    DetectionHistory detections = 3;
 | 
			
		||||
    RLEDetectionHistory rle_detections = 4;
 | 
			
		||||
    bool not_present = 5;
 | 
			
		||||
  }
 | 
			
		||||
  bool is_static = 6;
 | 
			
		||||
  CollisionInfo start_info = 7;
 | 
			
		||||
  CollisionInfo end_info = 8;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message IdentifierHistory {
 | 
			
		||||
  uint32 ball_identifier = 1;
 | 
			
		||||
  repeated Path paths = 2;
 | 
			
		||||
}
 | 
			
		||||
message KeyBallIdentifiers {
 | 
			
		||||
  uint32 cue_ball = 1;
 | 
			
		||||
  uint32 object_ball = 2;
 | 
			
		||||
  uint32 target_ball = 3;
 | 
			
		||||
 | 
			
		||||
  // For now this will just be cue->object/target->target
 | 
			
		||||
  // Long term this will potentially represent a linked list
 | 
			
		||||
  // of all balls in a shot.
 | 
			
		||||
  repeated uint32 contact_sequence = 4;
 | 
			
		||||
 | 
			
		||||
  optional uint32 cue_ball_id = 5;
 | 
			
		||||
  optional uint32 object_ball_id = 6;
 | 
			
		||||
  optional uint32 target_ball_id = 7;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message Shot {
 | 
			
		||||
  repeated IdentifierHistory identifier_histories = 3;
 | 
			
		||||
  KeyBallIdentifiers key_balls = 4;
 | 
			
		||||
  uint32 start_index = 5;
 | 
			
		||||
  uint32 end_index = 6;
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -427,6 +427,150 @@ function _decodeDetectionHistory(bb: ByteBuffer): DetectionHistory {
 | 
			
		||||
  return message;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export interface CollisionInfo {
 | 
			
		||||
  source?: number;
 | 
			
		||||
  ball_identifiers?: { [key: number]: Point };
 | 
			
		||||
  wall_identifier?: number;
 | 
			
		||||
  frame_index?: number;
 | 
			
		||||
  static?: boolean;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function encodeCollisionInfo(message: CollisionInfo): Uint8Array {
 | 
			
		||||
  let bb = popByteBuffer();
 | 
			
		||||
  _encodeCollisionInfo(message, bb);
 | 
			
		||||
  return toUint8Array(bb);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _encodeCollisionInfo(message: CollisionInfo, bb: ByteBuffer): void {
 | 
			
		||||
  // optional uint32 source = 1;
 | 
			
		||||
  let $source = message.source;
 | 
			
		||||
  if ($source !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 8);
 | 
			
		||||
    writeVarint32(bb, $source);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional map<uint32, Point> ball_identifiers = 2;
 | 
			
		||||
  let map$ball_identifiers = message.ball_identifiers;
 | 
			
		||||
  if (map$ball_identifiers !== undefined) {
 | 
			
		||||
    for (let key in map$ball_identifiers) {
 | 
			
		||||
      let nested = popByteBuffer();
 | 
			
		||||
      let value = map$ball_identifiers[key];
 | 
			
		||||
      writeVarint32(nested, 8);
 | 
			
		||||
      writeVarint32(nested, +key);
 | 
			
		||||
      writeVarint32(nested, 18);
 | 
			
		||||
      let nestedValue = popByteBuffer();
 | 
			
		||||
      _encodePoint(value, nestedValue);
 | 
			
		||||
      writeVarint32(nested, nestedValue.limit);
 | 
			
		||||
      writeByteBuffer(nested, nestedValue);
 | 
			
		||||
      pushByteBuffer(nestedValue);
 | 
			
		||||
      writeVarint32(bb, 18);
 | 
			
		||||
      writeVarint32(bb, nested.offset);
 | 
			
		||||
      writeByteBuffer(bb, nested);
 | 
			
		||||
      pushByteBuffer(nested);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional uint32 wall_identifier = 3;
 | 
			
		||||
  let $wall_identifier = message.wall_identifier;
 | 
			
		||||
  if ($wall_identifier !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 24);
 | 
			
		||||
    writeVarint32(bb, $wall_identifier);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional uint32 frame_index = 4;
 | 
			
		||||
  let $frame_index = message.frame_index;
 | 
			
		||||
  if ($frame_index !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 32);
 | 
			
		||||
    writeVarint32(bb, $frame_index);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional bool static = 5;
 | 
			
		||||
  let $static = message.static;
 | 
			
		||||
  if ($static !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 40);
 | 
			
		||||
    writeByte(bb, $static ? 1 : 0);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function decodeCollisionInfo(binary: Uint8Array): CollisionInfo {
 | 
			
		||||
  return _decodeCollisionInfo(wrapByteBuffer(binary));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _decodeCollisionInfo(bb: ByteBuffer): CollisionInfo {
 | 
			
		||||
  let message: CollisionInfo = {} as any;
 | 
			
		||||
 | 
			
		||||
  end_of_message: while (!isAtEnd(bb)) {
 | 
			
		||||
    let tag = readVarint32(bb);
 | 
			
		||||
 | 
			
		||||
    switch (tag >>> 3) {
 | 
			
		||||
      case 0:
 | 
			
		||||
        break end_of_message;
 | 
			
		||||
 | 
			
		||||
      // optional uint32 source = 1;
 | 
			
		||||
      case 1: {
 | 
			
		||||
        message.source = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional map<uint32, Point> ball_identifiers = 2;
 | 
			
		||||
      case 2: {
 | 
			
		||||
        let values =
 | 
			
		||||
          message.ball_identifiers || (message.ball_identifiers = {});
 | 
			
		||||
        let outerLimit = pushTemporaryLength(bb);
 | 
			
		||||
        let key: number | undefined;
 | 
			
		||||
        let value: Point | undefined;
 | 
			
		||||
        end_of_entry: while (!isAtEnd(bb)) {
 | 
			
		||||
          let tag = readVarint32(bb);
 | 
			
		||||
          switch (tag >>> 3) {
 | 
			
		||||
            case 0:
 | 
			
		||||
              break end_of_entry;
 | 
			
		||||
            case 1: {
 | 
			
		||||
              key = readVarint32(bb) >>> 0;
 | 
			
		||||
              break;
 | 
			
		||||
            }
 | 
			
		||||
            case 2: {
 | 
			
		||||
              let valueLimit = pushTemporaryLength(bb);
 | 
			
		||||
              value = _decodePoint(bb);
 | 
			
		||||
              bb.limit = valueLimit;
 | 
			
		||||
              break;
 | 
			
		||||
            }
 | 
			
		||||
            default:
 | 
			
		||||
              skipUnknownField(bb, tag & 7);
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
        if (key === undefined || value === undefined)
 | 
			
		||||
          throw new Error("Invalid data for map: ball_identifiers");
 | 
			
		||||
        values[key] = value;
 | 
			
		||||
        bb.limit = outerLimit;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional uint32 wall_identifier = 3;
 | 
			
		||||
      case 3: {
 | 
			
		||||
        message.wall_identifier = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional uint32 frame_index = 4;
 | 
			
		||||
      case 4: {
 | 
			
		||||
        message.frame_index = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional bool static = 5;
 | 
			
		||||
      case 5: {
 | 
			
		||||
        message.static = !!readByte(bb);
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      default:
 | 
			
		||||
        skipUnknownField(bb, tag & 7);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return message;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export interface Path {
 | 
			
		||||
  start_frame?: number;
 | 
			
		||||
  end_frame?: number;
 | 
			
		||||
@@ -434,6 +578,8 @@ export interface Path {
 | 
			
		||||
  rle_detections?: RLEDetectionHistory;
 | 
			
		||||
  not_present?: boolean;
 | 
			
		||||
  is_static?: boolean;
 | 
			
		||||
  start_info?: CollisionInfo;
 | 
			
		||||
  end_info?: CollisionInfo;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function encodePath(message: Path): Uint8Array {
 | 
			
		||||
@@ -492,6 +638,28 @@ function _encodePath(message: Path, bb: ByteBuffer): void {
 | 
			
		||||
    writeVarint32(bb, 48);
 | 
			
		||||
    writeByte(bb, $is_static ? 1 : 0);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional CollisionInfo start_info = 7;
 | 
			
		||||
  let $start_info = message.start_info;
 | 
			
		||||
  if ($start_info !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 58);
 | 
			
		||||
    let nested = popByteBuffer();
 | 
			
		||||
    _encodeCollisionInfo($start_info, nested);
 | 
			
		||||
    writeVarint32(bb, nested.limit);
 | 
			
		||||
    writeByteBuffer(bb, nested);
 | 
			
		||||
    pushByteBuffer(nested);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional CollisionInfo end_info = 8;
 | 
			
		||||
  let $end_info = message.end_info;
 | 
			
		||||
  if ($end_info !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 66);
 | 
			
		||||
    let nested = popByteBuffer();
 | 
			
		||||
    _encodeCollisionInfo($end_info, nested);
 | 
			
		||||
    writeVarint32(bb, nested.limit);
 | 
			
		||||
    writeByteBuffer(bb, nested);
 | 
			
		||||
    pushByteBuffer(nested);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function decodePath(binary: Uint8Array): Path {
 | 
			
		||||
@@ -548,6 +716,22 @@ function _decodePath(bb: ByteBuffer): Path {
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional CollisionInfo start_info = 7;
 | 
			
		||||
      case 7: {
 | 
			
		||||
        let limit = pushTemporaryLength(bb);
 | 
			
		||||
        message.start_info = _decodeCollisionInfo(bb);
 | 
			
		||||
        bb.limit = limit;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional CollisionInfo end_info = 8;
 | 
			
		||||
      case 8: {
 | 
			
		||||
        let limit = pushTemporaryLength(bb);
 | 
			
		||||
        message.end_info = _decodeCollisionInfo(bb);
 | 
			
		||||
        bb.limit = limit;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      default:
 | 
			
		||||
        skipUnknownField(bb, tag & 7);
 | 
			
		||||
    }
 | 
			
		||||
@@ -631,8 +815,165 @@ function _decodeIdentifierHistory(bb: ByteBuffer): IdentifierHistory {
 | 
			
		||||
  return message;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export interface KeyBallIdentifiers {
 | 
			
		||||
  cue_ball?: number;
 | 
			
		||||
  object_ball?: number;
 | 
			
		||||
  target_ball?: number;
 | 
			
		||||
  contact_sequence?: number[];
 | 
			
		||||
  cue_ball_id?: number;
 | 
			
		||||
  object_ball_id?: number;
 | 
			
		||||
  target_ball_id?: number;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function encodeKeyBallIdentifiers(
 | 
			
		||||
  message: KeyBallIdentifiers,
 | 
			
		||||
): Uint8Array {
 | 
			
		||||
  let bb = popByteBuffer();
 | 
			
		||||
  _encodeKeyBallIdentifiers(message, bb);
 | 
			
		||||
  return toUint8Array(bb);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _encodeKeyBallIdentifiers(
 | 
			
		||||
  message: KeyBallIdentifiers,
 | 
			
		||||
  bb: ByteBuffer,
 | 
			
		||||
): void {
 | 
			
		||||
  // optional uint32 cue_ball = 1;
 | 
			
		||||
  let $cue_ball = message.cue_ball;
 | 
			
		||||
  if ($cue_ball !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 8);
 | 
			
		||||
    writeVarint32(bb, $cue_ball);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional uint32 object_ball = 2;
 | 
			
		||||
  let $object_ball = message.object_ball;
 | 
			
		||||
  if ($object_ball !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 16);
 | 
			
		||||
    writeVarint32(bb, $object_ball);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional uint32 target_ball = 3;
 | 
			
		||||
  let $target_ball = message.target_ball;
 | 
			
		||||
  if ($target_ball !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 24);
 | 
			
		||||
    writeVarint32(bb, $target_ball);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // repeated uint32 contact_sequence = 4;
 | 
			
		||||
  let array$contact_sequence = message.contact_sequence;
 | 
			
		||||
  if (array$contact_sequence !== undefined) {
 | 
			
		||||
    let packed = popByteBuffer();
 | 
			
		||||
    for (let value of array$contact_sequence) {
 | 
			
		||||
      writeVarint32(packed, value);
 | 
			
		||||
    }
 | 
			
		||||
    writeVarint32(bb, 34);
 | 
			
		||||
    writeVarint32(bb, packed.offset);
 | 
			
		||||
    writeByteBuffer(bb, packed);
 | 
			
		||||
    pushByteBuffer(packed);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional uint32 cue_ball_id = 5;
 | 
			
		||||
  let $cue_ball_id = message.cue_ball_id;
 | 
			
		||||
  if ($cue_ball_id !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 40);
 | 
			
		||||
    writeVarint32(bb, $cue_ball_id);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional uint32 object_ball_id = 6;
 | 
			
		||||
  let $object_ball_id = message.object_ball_id;
 | 
			
		||||
  if ($object_ball_id !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 48);
 | 
			
		||||
    writeVarint32(bb, $object_ball_id);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional uint32 target_ball_id = 7;
 | 
			
		||||
  let $target_ball_id = message.target_ball_id;
 | 
			
		||||
  if ($target_ball_id !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 56);
 | 
			
		||||
    writeVarint32(bb, $target_ball_id);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function decodeKeyBallIdentifiers(
 | 
			
		||||
  binary: Uint8Array,
 | 
			
		||||
): KeyBallIdentifiers {
 | 
			
		||||
  return _decodeKeyBallIdentifiers(wrapByteBuffer(binary));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _decodeKeyBallIdentifiers(bb: ByteBuffer): KeyBallIdentifiers {
 | 
			
		||||
  let message: KeyBallIdentifiers = {} as any;
 | 
			
		||||
 | 
			
		||||
  end_of_message: while (!isAtEnd(bb)) {
 | 
			
		||||
    let tag = readVarint32(bb);
 | 
			
		||||
 | 
			
		||||
    switch (tag >>> 3) {
 | 
			
		||||
      case 0:
 | 
			
		||||
        break end_of_message;
 | 
			
		||||
 | 
			
		||||
      // optional uint32 cue_ball = 1;
 | 
			
		||||
      case 1: {
 | 
			
		||||
        message.cue_ball = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional uint32 object_ball = 2;
 | 
			
		||||
      case 2: {
 | 
			
		||||
        message.object_ball = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional uint32 target_ball = 3;
 | 
			
		||||
      case 3: {
 | 
			
		||||
        message.target_ball = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // repeated uint32 contact_sequence = 4;
 | 
			
		||||
      case 4: {
 | 
			
		||||
        let values =
 | 
			
		||||
          message.contact_sequence || (message.contact_sequence = []);
 | 
			
		||||
        if ((tag & 7) === 2) {
 | 
			
		||||
          let outerLimit = pushTemporaryLength(bb);
 | 
			
		||||
          while (!isAtEnd(bb)) {
 | 
			
		||||
            values.push(readVarint32(bb) >>> 0);
 | 
			
		||||
          }
 | 
			
		||||
          bb.limit = outerLimit;
 | 
			
		||||
        } else {
 | 
			
		||||
          values.push(readVarint32(bb) >>> 0);
 | 
			
		||||
        }
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional uint32 cue_ball_id = 5;
 | 
			
		||||
      case 5: {
 | 
			
		||||
        message.cue_ball_id = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional uint32 object_ball_id = 6;
 | 
			
		||||
      case 6: {
 | 
			
		||||
        message.object_ball_id = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional uint32 target_ball_id = 7;
 | 
			
		||||
      case 7: {
 | 
			
		||||
        message.target_ball_id = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      default:
 | 
			
		||||
        skipUnknownField(bb, tag & 7);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return message;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export interface Shot {
 | 
			
		||||
  identifier_histories?: IdentifierHistory[];
 | 
			
		||||
  key_balls?: KeyBallIdentifiers;
 | 
			
		||||
  start_index?: number;
 | 
			
		||||
  end_index?: number;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function encodeShot(message: Shot): Uint8Array {
 | 
			
		||||
@@ -654,6 +995,31 @@ function _encodeShot(message: Shot, bb: ByteBuffer): void {
 | 
			
		||||
      pushByteBuffer(nested);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional KeyBallIdentifiers key_balls = 4;
 | 
			
		||||
  let $key_balls = message.key_balls;
 | 
			
		||||
  if ($key_balls !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 34);
 | 
			
		||||
    let nested = popByteBuffer();
 | 
			
		||||
    _encodeKeyBallIdentifiers($key_balls, nested);
 | 
			
		||||
    writeVarint32(bb, nested.limit);
 | 
			
		||||
    writeByteBuffer(bb, nested);
 | 
			
		||||
    pushByteBuffer(nested);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional uint32 start_index = 5;
 | 
			
		||||
  let $start_index = message.start_index;
 | 
			
		||||
  if ($start_index !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 40);
 | 
			
		||||
    writeVarint32(bb, $start_index);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // optional uint32 end_index = 6;
 | 
			
		||||
  let $end_index = message.end_index;
 | 
			
		||||
  if ($end_index !== undefined) {
 | 
			
		||||
    writeVarint32(bb, 48);
 | 
			
		||||
    writeVarint32(bb, $end_index);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function decodeShot(binary: Uint8Array): Shot {
 | 
			
		||||
@@ -680,6 +1046,26 @@ function _decodeShot(bb: ByteBuffer): Shot {
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional KeyBallIdentifiers key_balls = 4;
 | 
			
		||||
      case 4: {
 | 
			
		||||
        let limit = pushTemporaryLength(bb);
 | 
			
		||||
        message.key_balls = _decodeKeyBallIdentifiers(bb);
 | 
			
		||||
        bb.limit = limit;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional uint32 start_index = 5;
 | 
			
		||||
      case 5: {
 | 
			
		||||
        message.start_index = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // optional uint32 end_index = 6;
 | 
			
		||||
      case 6: {
 | 
			
		||||
        message.end_index = readVarint32(bb) >>> 0;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      default:
 | 
			
		||||
        skipUnknownField(bb, tag & 7);
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										1169
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										1169
									
								
								src/index.tsx
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -1,45 +1,11 @@
 | 
			
		||||
query GetShots(
 | 
			
		||||
  $filterInput: FilterInput!
 | 
			
		||||
  $shotsPagination: GetShotsPagination
 | 
			
		||||
  $limit: Int
 | 
			
		||||
  $includeCreatedAt: Boolean! = false
 | 
			
		||||
  $includeUpdatedAt: Boolean! = false
 | 
			
		||||
  $includeCueObjectFeatures: Boolean! = false
 | 
			
		||||
  $includePocketingIntentionFeatures: Boolean! = false
 | 
			
		||||
  $includeCueObjectDistance: Boolean! = false
 | 
			
		||||
  $includeCueObjectAngle: Boolean! = false
 | 
			
		||||
  $includeCueBallSpeed: Boolean! = false
 | 
			
		||||
  $includeShotDirection: Boolean! = false
 | 
			
		||||
  $includeTargetPocketDistance: Boolean! = false
 | 
			
		||||
  $includeMake: Boolean! = false
 | 
			
		||||
  $includeIntendedPocketType: Boolean! = false
 | 
			
		||||
) {
 | 
			
		||||
  getShots(
 | 
			
		||||
    filterInput: $filterInput
 | 
			
		||||
    shotsPagination: $shotsPagination
 | 
			
		||||
    limit: $limit
 | 
			
		||||
  ) {
 | 
			
		||||
query GetSerializedShotPaths($filterInput: FilterInput!) {
 | 
			
		||||
  getShots(filterInput: $filterInput) {
 | 
			
		||||
    id
 | 
			
		||||
    videoId
 | 
			
		||||
    startFrame
 | 
			
		||||
    endFrame
 | 
			
		||||
    user {
 | 
			
		||||
      id
 | 
			
		||||
    }
 | 
			
		||||
    falsePositiveScore
 | 
			
		||||
    createdAt @include(if: $includeCreatedAt)
 | 
			
		||||
    updatedAt @include(if: $includeUpdatedAt)
 | 
			
		||||
    cueObjectFeatures @include(if: $includeCueObjectFeatures) {
 | 
			
		||||
      cueObjectDistance @include(if: $includeCueObjectDistance)
 | 
			
		||||
      cueObjectAngle @include(if: $includeCueObjectAngle)
 | 
			
		||||
      cueBallSpeed @include(if: $includeCueBallSpeed)
 | 
			
		||||
      shotDirection @include(if: $includeShotDirection)
 | 
			
		||||
    }
 | 
			
		||||
    pocketingIntentionFeatures
 | 
			
		||||
      @include(if: $includePocketingIntentionFeatures) {
 | 
			
		||||
      targetPocketDistance @include(if: $includeTargetPocketDistance)
 | 
			
		||||
      make @include(if: $includeMake)
 | 
			
		||||
      intendedPocketType @include(if: $includeIntendedPocketType)
 | 
			
		||||
    serializedShotPaths {
 | 
			
		||||
      b64EncodedBuffer
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
@@ -50,3 +16,70 @@ query GetShotAnnotationTypes {
 | 
			
		||||
    name
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
query GetShotsWithMetadata(
 | 
			
		||||
  $filterInput: FilterInput!
 | 
			
		||||
  $shotsPagination: GetShotsPagination
 | 
			
		||||
  $limit: Int
 | 
			
		||||
  $ids: [Int!]
 | 
			
		||||
) {
 | 
			
		||||
  getShotsWithMetadata(
 | 
			
		||||
    filterInput: $filterInput
 | 
			
		||||
    shotsPagination: $shotsPagination
 | 
			
		||||
    limit: $limit
 | 
			
		||||
    ids: $ids
 | 
			
		||||
  ) {
 | 
			
		||||
    count
 | 
			
		||||
    shots {
 | 
			
		||||
      ...ShotWithAllFeatures
 | 
			
		||||
    }
 | 
			
		||||
    ids
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
query GetShotsByIds($ids: [Int!]!) {
 | 
			
		||||
  getShotsByIds(ids: $ids) {
 | 
			
		||||
    ...ShotWithAllFeatures
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
fragment ShotWithAllFeatures on ShotGQL {
 | 
			
		||||
  id
 | 
			
		||||
  videoId
 | 
			
		||||
  startFrame
 | 
			
		||||
  endFrame
 | 
			
		||||
  user {
 | 
			
		||||
    id
 | 
			
		||||
  }
 | 
			
		||||
  falsePositiveScore
 | 
			
		||||
  video {
 | 
			
		||||
    stream {
 | 
			
		||||
      resolution {
 | 
			
		||||
        width
 | 
			
		||||
        height
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
  createdAt
 | 
			
		||||
  updatedAt
 | 
			
		||||
  cueObjectFeatures {
 | 
			
		||||
    cueObjectDistance
 | 
			
		||||
    cueObjectAngle
 | 
			
		||||
    cueBallSpeed
 | 
			
		||||
    shotDirection
 | 
			
		||||
    spinType
 | 
			
		||||
  }
 | 
			
		||||
  pocketingIntentionFeatures {
 | 
			
		||||
    targetPocketDistance
 | 
			
		||||
    make
 | 
			
		||||
    intendedPocketType
 | 
			
		||||
  }
 | 
			
		||||
  pocketingIntentionInfo {
 | 
			
		||||
    ballId
 | 
			
		||||
    pocketId
 | 
			
		||||
    pathMetadataIndex
 | 
			
		||||
  }
 | 
			
		||||
  serializedShotPaths {
 | 
			
		||||
    b64EncodedBuffer
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -56,3 +56,10 @@ query getUsernames(
 | 
			
		||||
) {
 | 
			
		||||
  getUsernames(matchString: $matchString, limit: $limit, after: $after)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
query GetUserTags {
 | 
			
		||||
  getUserTags {
 | 
			
		||||
    id
 | 
			
		||||
    name
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -4,7 +4,7 @@ query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) {
 | 
			
		||||
    totalShots
 | 
			
		||||
    makePercentage
 | 
			
		||||
    elapsedTime
 | 
			
		||||
    homographyHistory {
 | 
			
		||||
    currentHomography {
 | 
			
		||||
      crop {
 | 
			
		||||
        left
 | 
			
		||||
        top
 | 
			
		||||
@@ -118,11 +118,10 @@ query GetVideoDetails($videoId: Int!) {
 | 
			
		||||
query GetVideos($videoIds: [Int!]!) {
 | 
			
		||||
  getVideos(videoIds: $videoIds) {
 | 
			
		||||
    id
 | 
			
		||||
    playlist {
 | 
			
		||||
      segmentDurations
 | 
			
		||||
    }
 | 
			
		||||
    framesPerSecond
 | 
			
		||||
    stream {
 | 
			
		||||
      id
 | 
			
		||||
      streamSegmentType
 | 
			
		||||
      segments {
 | 
			
		||||
        uploaded
 | 
			
		||||
        valid
 | 
			
		||||
@@ -131,6 +130,9 @@ query GetVideos($videoIds: [Int!]!) {
 | 
			
		||||
        framesPerSecond
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    playlist {
 | 
			
		||||
      segmentDurations
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -55,6 +55,12 @@ mutation GetHlsInitUploadLink($videoId: Int!) {
 | 
			
		||||
          ... on NoInitForChunkedUploadErr {
 | 
			
		||||
            segmentType
 | 
			
		||||
          }
 | 
			
		||||
          ... on InitUploadAlreadyCompletedErr {
 | 
			
		||||
            segmentType
 | 
			
		||||
          }
 | 
			
		||||
          ... on TooManyInitUploadsErr {
 | 
			
		||||
            linksRequested
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										156
									
								
								src/schema.gql
									
									
									
									
									
								
							
							
						
						
									
										156
									
								
								src/schema.gql
									
									
									
									
									
								
							@@ -9,11 +9,18 @@ type Query {
 | 
			
		||||
    videoId: ID!
 | 
			
		||||
    intervalDuration: Int! = 300
 | 
			
		||||
  ): [MakePercentageIntervalGQL!]!
 | 
			
		||||
  getShotsWithMetadata(
 | 
			
		||||
    filterInput: FilterInput!
 | 
			
		||||
    ids: [Int!] = null
 | 
			
		||||
    shotsPagination: GetShotsPagination = null
 | 
			
		||||
    limit: Int! = 500
 | 
			
		||||
  ): GetShotsResult!
 | 
			
		||||
  getShots(
 | 
			
		||||
    filterInput: FilterInput!
 | 
			
		||||
    shotsPagination: GetShotsPagination = null
 | 
			
		||||
    limit: Int! = 500
 | 
			
		||||
  ): [ShotGQL!]!
 | 
			
		||||
  getShotsByIds(ids: [Int!]!): [ShotGQL!]!
 | 
			
		||||
  getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]!
 | 
			
		||||
  getUser(userId: Int!): UserGQL
 | 
			
		||||
  getLoggedInUser: UserGQL
 | 
			
		||||
@@ -48,6 +55,21 @@ type TargetMetricsGQL {
 | 
			
		||||
  count: Int!
 | 
			
		||||
  makePercentage: Float
 | 
			
		||||
  averageDifficulty: Float
 | 
			
		||||
  spinTypeCounts: SpinTypeCountsGQL
 | 
			
		||||
  shotDirectionCounts: ShotDirectionCountsGQL
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type SpinTypeCountsGQL {
 | 
			
		||||
  follow: Int!
 | 
			
		||||
  draw: Int!
 | 
			
		||||
  center: Int!
 | 
			
		||||
  unknown: Int!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type ShotDirectionCountsGQL {
 | 
			
		||||
  left: Int!
 | 
			
		||||
  right: Int!
 | 
			
		||||
  straight: Int!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
input AggregateInputGQL {
 | 
			
		||||
@@ -58,6 +80,7 @@ input AggregateInputGQL {
 | 
			
		||||
input AggregationInput @oneOf {
 | 
			
		||||
  bucketSet: BucketSetInputGQL
 | 
			
		||||
  enum: EnumAggregation
 | 
			
		||||
  datetimeRange: DatetimeRangeAggregationInput
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
input BucketSetInputGQL {
 | 
			
		||||
@@ -74,15 +97,46 @@ input EnumAggregation {
 | 
			
		||||
  feature: String!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
input DatetimeRangeAggregationInput {
 | 
			
		||||
  startDatetime: DateTime = null
 | 
			
		||||
  endDatetime: DateTime = null
 | 
			
		||||
  interval: TimeInterval!
 | 
			
		||||
  feature: String! = "created_at"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
"""
 | 
			
		||||
Date with time (isoformat)
 | 
			
		||||
"""
 | 
			
		||||
scalar DateTime
 | 
			
		||||
 | 
			
		||||
input TimeInterval @oneOf {
 | 
			
		||||
  timedelta: TimeDeltaGQL
 | 
			
		||||
  aligned: AlignedIntervalEnum
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
input TimeDeltaGQL {
 | 
			
		||||
  days: Int = 0
 | 
			
		||||
  weeks: Int = 0
 | 
			
		||||
  months: Int = 0
 | 
			
		||||
  years: Int = 0
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
enum AlignedIntervalEnum {
 | 
			
		||||
  MONTH
 | 
			
		||||
  YEAR
 | 
			
		||||
  WEEK
 | 
			
		||||
  DAY
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
input FilterInput @oneOf {
 | 
			
		||||
  andFilters: [FilterInput!]
 | 
			
		||||
  orFilters: [FilterInput!]
 | 
			
		||||
  notFilter: FilterInput
 | 
			
		||||
  cueObjectDistance: RangeFilter
 | 
			
		||||
  targetPocketDistance: RangeFilter
 | 
			
		||||
  cueObjectAngle: RangeFilter
 | 
			
		||||
  cueBallSpeed: RangeFilter
 | 
			
		||||
  difficulty: RangeFilter
 | 
			
		||||
  cueObjectDistance: FloatRangeFilter
 | 
			
		||||
  targetPocketDistance: FloatRangeFilter
 | 
			
		||||
  cueObjectAngle: FloatRangeFilter
 | 
			
		||||
  cueBallSpeed: FloatRangeFilter
 | 
			
		||||
  difficulty: FloatRangeFilter
 | 
			
		||||
  intendedPocketType: [PocketEnum!]
 | 
			
		||||
  shotDirection: [ShotDirectionEnum!]
 | 
			
		||||
  videoId: [Int!]
 | 
			
		||||
@@ -96,18 +150,23 @@ input FilterInput @oneOf {
 | 
			
		||||
  isLeftMiss: [Boolean!]
 | 
			
		||||
  isRightMiss: [Boolean!]
 | 
			
		||||
  isDirect: [Boolean!]
 | 
			
		||||
  tableSize: RangeFilter
 | 
			
		||||
  bankAngle: RangeFilter
 | 
			
		||||
  bankDistance: RangeFilter
 | 
			
		||||
  kickAngle: RangeFilter
 | 
			
		||||
  kickDistance: RangeFilter
 | 
			
		||||
  cueAngleAfterObject: RangeFilter
 | 
			
		||||
  cueSpeedAfterObject: RangeFilter
 | 
			
		||||
  spinType: [String!]
 | 
			
		||||
  falsePositiveScore: RangeFilter
 | 
			
		||||
  tableSize: FloatRangeFilter
 | 
			
		||||
  bankAngle: FloatRangeFilter
 | 
			
		||||
  bankDistance: FloatRangeFilter
 | 
			
		||||
  kickAngle: FloatRangeFilter
 | 
			
		||||
  kickDistance: FloatRangeFilter
 | 
			
		||||
  cueAngleAfterObject: FloatRangeFilter
 | 
			
		||||
  spinType: [SpinTypeEnum!]
 | 
			
		||||
  cueSpeedAfterObject: FloatRangeFilter
 | 
			
		||||
  falsePositiveScore: FloatRangeFilter
 | 
			
		||||
  backcut: [Boolean!]
 | 
			
		||||
  targetPocketAngleDirection: [ShotDirectionEnum!]
 | 
			
		||||
  targetPocketAngle: FloatRangeFilter
 | 
			
		||||
  missAngleInDegrees: FloatRangeFilter
 | 
			
		||||
  createdAt: DateRangeFilter
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
input RangeFilter {
 | 
			
		||||
input FloatRangeFilter {
 | 
			
		||||
  lessThan: Float = null
 | 
			
		||||
  greaterThanEqualTo: Float = null
 | 
			
		||||
  greaterThan: Float = null
 | 
			
		||||
@@ -140,6 +199,27 @@ input ShotAnnotationInput {
 | 
			
		||||
  name: String!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
enum SpinTypeEnum {
 | 
			
		||||
  DRAW
 | 
			
		||||
  FOLLOW
 | 
			
		||||
  CENTER
 | 
			
		||||
  UNKNOWN
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
input DateRangeFilter {
 | 
			
		||||
  lessThan: Date = null
 | 
			
		||||
  greaterThanEqualTo: Date = null
 | 
			
		||||
  greaterThan: Date = null
 | 
			
		||||
  includeOnNone: Boolean! = false
 | 
			
		||||
  lessThanInclusive: Boolean! = false
 | 
			
		||||
  greaterThanInclusive: Boolean! = true
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
"""
 | 
			
		||||
Date (isoformat)
 | 
			
		||||
"""
 | 
			
		||||
scalar Date
 | 
			
		||||
 | 
			
		||||
type BucketSetGQL {
 | 
			
		||||
  keyName: String!
 | 
			
		||||
  feature: String!
 | 
			
		||||
@@ -164,6 +244,12 @@ type MakePercentageIntervalGQL {
 | 
			
		||||
  elapsedTime: Float!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type GetShotsResult {
 | 
			
		||||
  shots: [ShotGQL!]!
 | 
			
		||||
  count: Int
 | 
			
		||||
  ids: [Int!]!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type ShotGQL {
 | 
			
		||||
  id: Int!
 | 
			
		||||
  videoId: Int!
 | 
			
		||||
@@ -173,6 +259,7 @@ type ShotGQL {
 | 
			
		||||
  updatedAt: DateTime
 | 
			
		||||
  cueObjectFeatures: CueObjectFeaturesGQL
 | 
			
		||||
  pocketingIntentionFeatures: PocketingIntentionFeaturesGQL
 | 
			
		||||
  pocketingIntentionInfo: PocketingIntentionInfoGQL
 | 
			
		||||
  bankFeatures: BankFeaturesGQL
 | 
			
		||||
  serializedShotPaths: SerializedShotPathsGQL
 | 
			
		||||
  user: UserGQL
 | 
			
		||||
@@ -181,16 +268,12 @@ type ShotGQL {
 | 
			
		||||
  video: VideoGQL
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
"""
 | 
			
		||||
Date with time (isoformat)
 | 
			
		||||
"""
 | 
			
		||||
scalar DateTime
 | 
			
		||||
 | 
			
		||||
type CueObjectFeaturesGQL {
 | 
			
		||||
  cueObjectDistance: Float
 | 
			
		||||
  cueObjectAngle: Float
 | 
			
		||||
  cueBallSpeed: Float
 | 
			
		||||
  shotDirection: ShotDirectionEnum
 | 
			
		||||
  spinType: SpinTypeEnum
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type PocketingIntentionFeaturesGQL {
 | 
			
		||||
@@ -198,6 +281,24 @@ type PocketingIntentionFeaturesGQL {
 | 
			
		||||
  make: Boolean
 | 
			
		||||
  intendedPocketType: PocketEnum
 | 
			
		||||
  difficulty: Float
 | 
			
		||||
  targetPocketAngle: Float
 | 
			
		||||
  targetPocketAngleDirection: ShotDirectionEnum
 | 
			
		||||
  backcut: Boolean
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type PocketingIntentionInfoGQL {
 | 
			
		||||
  ballId: Int!
 | 
			
		||||
  pocketId: PocketIdentifier!
 | 
			
		||||
  pathMetadataIndex: Int!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
enum PocketIdentifier {
 | 
			
		||||
  TOP_LEFT
 | 
			
		||||
  TOP_SIDE
 | 
			
		||||
  TOP_RIGHT
 | 
			
		||||
  BOTTOM_LEFT
 | 
			
		||||
  BOTTOM_SIDE
 | 
			
		||||
  BOTTOM_RIGHT
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type BankFeaturesGQL {
 | 
			
		||||
@@ -262,6 +363,7 @@ type VideoGQL {
 | 
			
		||||
  stream: UploadStreamGQL
 | 
			
		||||
  playlist: HLSPlaylistGQL
 | 
			
		||||
  tags: [VideoTag!]!
 | 
			
		||||
  currentHomography: HomographyInfoGQL
 | 
			
		||||
  homographyHistory: [HomographyInfoGQL!]!
 | 
			
		||||
  currentProcessing: VideoProcessingGQL
 | 
			
		||||
}
 | 
			
		||||
@@ -568,15 +670,17 @@ type GetUploadLinkReturn {
 | 
			
		||||
union UploadLinkGetUploadLinkErrors = UploadLink | GetUploadLinkErrors
 | 
			
		||||
 | 
			
		||||
type GetUploadLinkErrors {
 | 
			
		||||
  error: MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErr!
 | 
			
		||||
  error: MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErrInitUploadAlreadyCompletedErrTooManyInitUploadsErr!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
union MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErr =
 | 
			
		||||
union MustHaveSetForUploadLinkErrSegmentAlreadyUploadedErrProcessingFailedErrNoInitForChunkedUploadErrTooManyProfileImageUploadsErrInitUploadAlreadyCompletedErrTooManyInitUploadsErr =
 | 
			
		||||
    MustHaveSetForUploadLinkErr
 | 
			
		||||
  | SegmentAlreadyUploadedErr
 | 
			
		||||
  | ProcessingFailedErr
 | 
			
		||||
  | NoInitForChunkedUploadErr
 | 
			
		||||
  | TooManyProfileImageUploadsErr
 | 
			
		||||
  | InitUploadAlreadyCompletedErr
 | 
			
		||||
  | TooManyInitUploadsErr
 | 
			
		||||
 | 
			
		||||
type MustHaveSetForUploadLinkErr {
 | 
			
		||||
  resolution: Boolean
 | 
			
		||||
@@ -594,3 +698,11 @@ type ProcessingFailedErr {
 | 
			
		||||
type NoInitForChunkedUploadErr {
 | 
			
		||||
  segmentType: StreamSegmentTypeEnum!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type InitUploadAlreadyCompletedErr {
 | 
			
		||||
  segmentType: StreamSegmentTypeEnum!
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type TooManyInitUploadsErr {
 | 
			
		||||
  linksRequested: Int!
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user