outputs.proto 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397
  1. // Copyright 2022 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. syntax = "proto3";
  15. package google.cloud.video.livestream.v1;
  16. import "google/api/field_behavior.proto";
  17. import "google/protobuf/duration.proto";
  18. option csharp_namespace = "Google.Cloud.Video.LiveStream.V1";
  19. option go_package = "google.golang.org/genproto/googleapis/cloud/video/livestream/v1;livestream";
  20. option java_multiple_files = true;
  21. option java_outer_classname = "OutputsProto";
  22. option java_package = "com.google.cloud.video.livestream.v1";
  23. option php_namespace = "Google\\Cloud\\Video\\LiveStream\\V1";
  24. option ruby_package = "Google::Cloud::Video::LiveStream::V1";
  25. // Encoding of an input element such as an audio, video, or text track.
  26. // Elementary streams must be packaged before mapping and sharing between
  27. // different output formats.
  28. message ElementaryStream {
  29. // A unique key for this elementary stream.
  30. string key = 4;
  31. // Required. Encoding of an audio, video, or text track.
  32. oneof elementary_stream {
  33. // Encoding of a video stream.
  34. VideoStream video_stream = 1;
  35. // Encoding of an audio stream.
  36. AudioStream audio_stream = 2;
  37. // Encoding of a text stream. For example, closed captions or subtitles.
  38. TextStream text_stream = 3;
  39. }
  40. }
  41. // Multiplexing settings for output stream.
  42. message MuxStream {
  43. // A unique key for this multiplexed stream.
  44. string key = 1;
  45. // The container format. The default is `fmp4`.
  46. //
  47. // Supported container formats:
  48. //
  49. // - `fmp4` - the corresponding file extension is `.m4s`
  50. // - `ts` - the corresponding file extension is `.ts`
  51. string container = 3;
  52. // List of `ElementaryStream` [key][google.cloud.video.livestream.v1.ElementaryStream.key]s multiplexed in this
  53. // stream.
  54. //
  55. // - For `fmp4` container, must contain either one video or one audio stream.
  56. // - For `ts` container, must contain exactly one audio stream and up to one
  57. // video stream.
  58. repeated string elementary_streams = 4;
  59. // Segment settings for `fmp4` and `ts`.
  60. SegmentSettings segment_settings = 5;
  61. }
  62. // Manifest configuration.
  63. message Manifest {
  64. // The manifest type can be either `HLS` or `DASH`.
  65. enum ManifestType {
  66. // The manifest type is not specified.
  67. MANIFEST_TYPE_UNSPECIFIED = 0;
  68. // Create an `HLS` manifest. The corresponding file extension is `.m3u8`.
  69. HLS = 1;
  70. // Create a `DASH` manifest. The corresponding file extension is `.mpd`.
  71. DASH = 2;
  72. }
  73. // The name of the generated file. The default is `manifest` with the
  74. // extension suffix corresponding to the `Manifest` [type][google.cloud.video.livestream.v1.Manifest.type]. If multiple
  75. // manifests are added to the channel, each must have a unique file name.
  76. string file_name = 1;
  77. // Required. Type of the manifest, can be `HLS` or `DASH`.
  78. ManifestType type = 2 [(google.api.field_behavior) = REQUIRED];
  79. // Required. List of `MuxStream` [key][google.cloud.video.livestream.v1.MuxStream.key]s that should appear in this
  80. // manifest.
  81. //
  82. // - For HLS, either `fmp4` or `ts` mux streams can be specified but not
  83. // mixed.
  84. // - For DASH, only `fmp4` mux streams can be specified.
  85. repeated string mux_streams = 3 [(google.api.field_behavior) = REQUIRED];
  86. // Maximum number of segments that this manifest holds. Once the manifest
  87. // reaches this maximum number of segments, whenever a new segment is added to
  88. // the manifest, the oldest segment will be removed from the manifest.
  89. // The minimum value is 3 and the default value is 5.
  90. int32 max_segment_count = 4;
  91. // How long to keep a segment on the output Google Cloud Storage bucket after
  92. // it is removed from the manifest. This field should be large enough to cover
  93. // the manifest propagation delay. Otherwise, a player could receive 404
  94. // errors while accessing segments which are listed in the manifest that the
  95. // player has, but were already deleted from the output Google Cloud Storage
  96. // bucket. Default value is `60s`.
  97. google.protobuf.Duration segment_keep_duration = 5;
  98. }
  99. // Sprite sheet configuration.
  100. message SpriteSheet {
  101. // Format type. The default is `jpeg`.
  102. //
  103. // Supported formats:
  104. //
  105. // - `jpeg`
  106. string format = 1;
  107. // Required. File name prefix for the generated sprite sheets. If multiple
  108. // sprite sheets are added to the channel, each must have a unique file
  109. // prefix.
  110. // Each sprite sheet has an incremental 10-digit zero-padded suffix starting
  111. // from 0 before the extension, such as `sprite_sheet0000000123.jpeg`.
  112. string file_prefix = 2 [(google.api.field_behavior) = REQUIRED];
  113. // Required. The width of the sprite in pixels. Must be an even integer.
  114. int32 sprite_width_pixels = 3 [(google.api.field_behavior) = REQUIRED];
  115. // Required. The height of the sprite in pixels. Must be an even integer.
  116. int32 sprite_height_pixels = 4 [(google.api.field_behavior) = REQUIRED];
  117. // The maximum number of sprites per row in a sprite sheet. Valid range is
  118. // [1, 10] and the default value is 1.
  119. int32 column_count = 5;
  120. // The maximum number of rows per sprite sheet. When the sprite sheet is full,
  121. // a new sprite sheet is created. Valid range is [1, 10] and the default value
  122. // is 1.
  123. int32 row_count = 6;
  124. // Create sprites at regular intervals. Valid range is [1 second, 1 hour] and
  125. // the default value is `10s`.
  126. google.protobuf.Duration interval = 7;
  127. // The quality of the generated sprite sheet. Enter a value between 1
  128. // and 100, where 1 is the lowest quality and 100 is the highest quality.
  129. // The default is 100. A high quality value corresponds to a low image data
  130. // compression ratio.
  131. int32 quality = 8;
  132. }
  133. // Preprocessing configurations.
  134. message PreprocessingConfig {
  135. // Video cropping configuration for the input video. The cropped input video
  136. // is scaled to match the output resolution.
  137. message Crop {
  138. // The number of pixels to crop from the top. The default is 0.
  139. int32 top_pixels = 1;
  140. // The number of pixels to crop from the bottom. The default is 0.
  141. int32 bottom_pixels = 2;
  142. // The number of pixels to crop from the left. The default is 0.
  143. int32 left_pixels = 3;
  144. // The number of pixels to crop from the right. The default is 0.
  145. int32 right_pixels = 4;
  146. }
  147. // Pad filter configuration for the input video. The padded input video
  148. // is scaled after padding with black to match the output resolution.
  149. message Pad {
  150. // The number of pixels to add to the top. The default is 0.
  151. int32 top_pixels = 1;
  152. // The number of pixels to add to the bottom. The default is 0.
  153. int32 bottom_pixels = 2;
  154. // The number of pixels to add to the left. The default is 0.
  155. int32 left_pixels = 3;
  156. // The number of pixels to add to the right. The default is 0.
  157. int32 right_pixels = 4;
  158. }
  159. // Specify the video cropping configuration.
  160. Crop crop = 2;
  161. // Specify the video pad filter configuration.
  162. Pad pad = 3;
  163. }
  164. // Video stream resource.
  165. message VideoStream {
  166. // H264 codec settings.
  167. message H264CodecSettings {
  168. // Required. The width of the video in pixels. Must be an even integer.
  169. // Valid range is [320, 1920].
  170. int32 width_pixels = 1;
  171. // Required. The height of the video in pixels. Must be an even integer.
  172. // Valid range is [180, 1080].
  173. int32 height_pixels = 2;
  174. // Required. The target video frame rate in frames per second (FPS). Must be less
  175. // than or equal to 60. Will default to the input frame rate if larger
  176. // than the input frame rate. The API will generate an output FPS that is
  177. // divisible by the input FPS, and smaller or equal to the target FPS. See
  178. // [Calculating frame
  179. // rate](https://cloud.google.com/transcoder/docs/concepts/frame-rate) for
  180. // more information.
  181. double frame_rate = 3 [(google.api.field_behavior) = REQUIRED];
  182. // Required. The video bitrate in bits per second. Minimum value is 10,000.
  183. //
  184. // - For SD resolution (< 720p), must be <= 3,000,000 (3 Mbps).
  185. // - For HD resolution (<= 1080p), must be <= 15,000,000 (15 Mbps).
  186. int32 bitrate_bps = 4 [(google.api.field_behavior) = REQUIRED];
  187. // Specifies whether an open Group of Pictures (GOP) structure should be
  188. // allowed or not. The default is `false`.
  189. bool allow_open_gop = 6;
  190. // GOP mode can be either by frame count or duration.
  191. oneof gop_mode {
  192. // Select the GOP size based on the specified frame count.
  193. // If GOP frame count is set instead of GOP duration, GOP duration will be
  194. // calculated by `gopFrameCount`/`frameRate`. The calculated GOP duration
  195. // must satisfy the limitations on `gopDuration` as well.
  196. // Valid range is [60, 600].
  197. int32 gop_frame_count = 7;
  198. // Select the GOP size based on the specified duration. The default is
  199. // `2s`. Note that `gopDuration` must be less than or equal to
  200. // [segment_duration][google.cloud.video.livestream.v1.SegmentSettings.segment_duration], and
  201. // [segment_duration][google.cloud.video.livestream.v1.SegmentSettings.segment_duration] must be divisible
  202. // by `gopDuration`. Valid range is [2s, 20s].
  203. //
  204. // All video streams in the same channel must have the same GOP size.
  205. google.protobuf.Duration gop_duration = 8;
  206. }
  207. // Size of the Video Buffering Verifier (VBV) buffer in bits. Must be
  208. // greater than zero. The default is equal to [bitrate_bps][google.cloud.video.livestream.v1.VideoStream.H264CodecSettings.bitrate_bps].
  209. int32 vbv_size_bits = 9;
  210. // Initial fullness of the Video Buffering Verifier (VBV) buffer in bits.
  211. // Must be greater than zero. The default is equal to 90% of
  212. // [vbv_size_bits][google.cloud.video.livestream.v1.VideoStream.H264CodecSettings.vbv_size_bits].
  213. int32 vbv_fullness_bits = 10;
  214. // The entropy coder to use. The default is `cabac`.
  215. //
  216. // Supported entropy coders:
  217. //
  218. // - `cavlc`
  219. // - `cabac`
  220. string entropy_coder = 11;
  221. // Allow B-pyramid for reference frame selection. This may not be supported
  222. // on all decoders. The default is `false`.
  223. bool b_pyramid = 12;
  224. // The number of consecutive B-frames. Must be greater than or equal to
  225. // zero. Must be less than [gop_frame_count][google.cloud.video.livestream.v1.VideoStream.H264CodecSettings.gop_frame_count] if set. The default
  226. // is 0.
  227. int32 b_frame_count = 13;
  228. // Specify the intensity of the adaptive quantizer (AQ). Must be between 0
  229. // and 1, where 0 disables the quantizer and 1 maximizes the quantizer. A
  230. // higher value equals a lower bitrate but smoother image. The default is 0.
  231. double aq_strength = 14;
  232. // Enforces the specified codec profile. The following profiles are
  233. // supported:
  234. //
  235. // * `baseline`
  236. // * `main` (default)
  237. // * `high`
  238. //
  239. // The available options are [FFmpeg-compatible Profile
  240. // Options](https://trac.ffmpeg.org/wiki/Encode/H.264#Profile).
  241. // Note that certain values for this field may cause the
  242. // transcoder to override other fields you set in the [H264CodecSettings][google.cloud.video.livestream.v1.VideoStream.H264CodecSettings]
  243. // message.
  244. string profile = 15;
  245. // Enforces the specified codec tune. The available options are
  246. // [FFmpeg-compatible Encode
  247. // Options](https://trac.ffmpeg.org/wiki/Encode/H.264#Tune)
  248. // Note that certain values for this field may cause the transcoder to
  249. // override other fields you set in the [H264CodecSettings][google.cloud.video.livestream.v1.VideoStream.H264CodecSettings] message.
  250. string tune = 16;
  251. }
  252. // Codec settings.
  253. oneof codec_settings {
  254. // H264 codec settings.
  255. H264CodecSettings h264 = 20;
  256. }
  257. }
  258. // Audio stream resource.
  259. message AudioStream {
  260. // The mapping for the input streams and audio channels.
  261. message AudioMapping {
  262. // Required. The `Channel` [InputAttachment.key][google.cloud.video.livestream.v1.InputAttachment.key] that identifies the input that this
  263. // audio mapping applies to. If an active input doesn't have an audio
  264. // mapping, the primary audio track in the input stream will be selected.
  265. string input_key = 6 [(google.api.field_behavior) = REQUIRED];
  266. // Required. The zero-based index of the track in the input stream.
  267. // All [mapping][google.cloud.video.livestream.v1.AudioStream.mapping]s in the same [AudioStream][google.cloud.video.livestream.v1.AudioStream]
  268. // must have the same input track.
  269. int32 input_track = 2 [(google.api.field_behavior) = REQUIRED];
  270. // Required. The zero-based index of the channel in the input stream.
  271. int32 input_channel = 3 [(google.api.field_behavior) = REQUIRED];
  272. // Required. The zero-based index of the channel in the output audio stream.
  273. // Must be consistent with the [input_channel][google.cloud.video.livestream.v1.AudioStream.AudioMapping.input_channel].
  274. int32 output_channel = 4 [(google.api.field_behavior) = REQUIRED];
  275. }
  276. // Specifies whether pass through (transmuxing) is enabled or not.
  277. // If set to `true`, the rest of the settings, other than `mapping`, will be
  278. // ignored. The default is `false`.
  279. bool transmux = 8;
  280. // The codec for this audio stream. The default is `aac`.
  281. //
  282. // Supported audio codecs:
  283. //
  284. // - `aac`
  285. string codec = 1;
  286. // Required. Audio bitrate in bits per second. Must be between 1 and 10,000,000.
  287. int32 bitrate_bps = 2 [(google.api.field_behavior) = REQUIRED];
  288. // Number of audio channels. Must be between 1 and 6. The default is 2.
  289. int32 channel_count = 3;
  290. // A list of channel names specifying layout of the audio channels.
  291. // This only affects the metadata embedded in the container headers, if
  292. // supported by the specified format. The default is `[fl, fr]`.
  293. //
  294. // Supported channel names:
  295. //
  296. // - `fl` - Front left channel
  297. // - `fr` - Front right channel
  298. // - `sl` - Side left channel
  299. // - `sr` - Side right channel
  300. // - `fc` - Front center channel
  301. // - `lfe` - Low frequency
  302. repeated string channel_layout = 4;
  303. // The mapping for the input streams and audio channels.
  304. repeated AudioMapping mapping = 5;
  305. // The audio sample rate in Hertz. The default is 48000 Hertz.
  306. int32 sample_rate_hertz = 6;
  307. }
  308. // Encoding of a text stream. For example, closed captions or subtitles.
  309. message TextStream {
  310. // Required. The codec for this text stream.
  311. //
  312. // Supported text codecs:
  313. //
  314. // - `cea608`
  315. // - `cea708`
  316. string codec = 1 [(google.api.field_behavior) = REQUIRED];
  317. }
  318. // Segment settings for `fmp4` and `ts`.
  319. message SegmentSettings {
  320. // Duration of the segments in seconds. The default is `6s`. Note that
  321. // `segmentDuration` must be greater than or equal to
  322. // [gop_duration][google.cloud.video.livestream.v1.VideoStream.H264CodecSettings.gop_duration], and
  323. // `segmentDuration` must be divisible by
  324. // [gop_duration][google.cloud.video.livestream.v1.VideoStream.H264CodecSettings.gop_duration].
  325. // Valid range is [2s, 20s].
  326. //
  327. // All [mux_streams][google.cloud.video.livestream.v1.Manifest.mux_streams] in the same manifest must have the
  328. // same segment duration.
  329. google.protobuf.Duration segment_duration = 1;
  330. }