Prevent conflict with lower and upper case for outlier cases
[goodguy/cin-manual-latex.git] / parts / Introduction.tex
1 \chapter*{Introduction}%
2 \label{cha:introduction}
3 \addcontentsline{toc}{chapter}{Introduction}
4
5 \CGG{} is a software program NLE, Non-Linear Editor, that provides a
6 way to edit, record, and play audio or video media.  It can also be
7 used to transcode media from one format to another or to correct and
8 retouch photos. \CGG{} currently runs on many Linux operating system
9 distributions.
10
11 This manual covers the \CGG{} \INF{} version.  Information
12 contained in this manual is a description of the \CGG{} program
13 usage and was obtained from various sources to include different
14 communication channels, emails, common knowledge, and write-ups as
15 new features were added.  The author of the original
16 \textsc{Cinelerra} program, Adam Williams, as well as many different
17 people have modified the \textsc{Cinelerra} source code over the
18 years.  William Morrow merged all of the known changes, whenever
19 possible, into this \CGG{} version and has been adding numerous
20 features, updates, and fixes.
21
22 {\small NOTE: This manual is a Work in Progress: monthly parts are added to cover the new features introduced in \CGG{}. The texts are continuously revised to make them clearer and more complete. In order to have a better and better product we rely on the suggestions and criticisms of our readers. Do not hesitate to let us know your opinions. For this continuous variability, we recommend that you download the manual at least once a month, during the release of \CGG{}, so that its content is always up to date.}
23
24 The \CGG{} software is under
25 \href{https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html}{GPLv2+}
26 license. A notice of this is included in the software and shown here.
27
28 \begin{lstlisting}[basicstyle=\footnotesize]
29 *
30 * CINELERRA
31 * Copyright (C) 1997-2012 Adam Williams <broadcast at earthling dot net>
32 *
33 * This program is free software; you can redistribute it and/or modify
34 * it under the terms of the GNU General Public License as published by
35 * the Free Software Foundation; either version 2 of the License, or
36 * (at your option) any later version.
37 *
38 * This program is distributed in the hope that it will be useful,
39 * but WITHOUT ANY WARRANTY; without even the implied warranty of
40 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
41 * GNU General Public License for more details.
42 *
43 * You should have received a copy of the GNU General Public License
44 * along with this program; if not, write to the Free Software
45 * Foundation, Inc., 59 Temple Place, Suite 330, Boston
46 \end{lstlisting}
47
48 \section*{\CGG{} Overview}%
49 \label{sec:cinelerra_overview}
50
51 Presented briefly here is an overview of \CGGI{} and information
52 provided in this manual. The \GG{} version of \textsc{Cinelerra} has
53 been improved for \emph{stability}, \emph{modernized} to accommodate
54 the \emph{current state} of Linux software, enhanced with additional
55 \emph{basic features}, and enriched with \emph{new features}
56 imagined by dedicated users and then implemented by professional
57 programmers.
58
59 \begin{description}
60     \item[Website] \href{https://www.cinelerra-gg.org}{https://www.cinelerra-gg.org}\\
61         The website for the cinelerra-gg software is a good place to start for information, help, and documentation.
62         It is professionally maintained and continuously updated with more language
63         translations ongoing.
64     \item[Stability]~\\
65         Software programs that \textit{just work} are a \#1 priority in order to be of use for producing quality videos.
66         A large amount of time has been invested in debugging problems and resolving crashes.
67         And in a continuous process to do so, a chapter on Troubleshooting is included in order to easily provide sufficient information for users to capture issues and crashes so that they can be analyzed and quickly fixed to avoid repeat problems.
68     \item[Modernization]~\\
69         Artistic creativity has been applied to modernize the \CGG{} plugin icons for video and audio to even include the ffmpeg plugins.
70         The Cinfinity set of plugin icons come in square or roundish versions --- your choice.
71         In keeping up with the current expectation of users for a certain \textit{look and feel}, 2 very modern recent theme additions, Cakewalk and Neophyte, provide alternatives to the already existing 9 themes.
72         These 11 themes give the user the choice to get the look they like best for their own eyes.
73     \item[Current and up-to-date]~\\
74         For today’s software, included thirdparty libraries are kept up to date in a timely manner and effort is made to always use a relatively recent version of FFmpeg, if not the latest.
75         This is a big deal because there is a whole set of separate programmers working on these libraries continuously and diligently to cover all of the old and newly created formats.
76         Thus \CGG{} programmers can be dedicated to working solely on \CGG{} rather than just trying to keep up with many formats.
77     \item[FFmpeg usage integration]~\\
78         By using FFmpeg with \CGG{}, there is the advantage that users can directly convert videos via pre- and post-processing, without the need for command lines to be executed manually before or afterwards.
79     \item[Import and Export formats]~\\
80         Listed here are only a few of the supported Import and Export formats:
81         \begin{itemize}
82             \item  several standard native formats, such as mpeg, ac3, flac, exr and jpeg/png/ppm/tiff sequences
83             \item FFmpeg’s over 400 decoders and 150 encoders accessible from within \CGG{} to include:
84                 mp4, mkv, mpeg, mov, m2ts, mp3, dvd, ogg, theora, prores, tiff, webm, flac, opus, vorbis,
85                 quicktime (div, dnxhd, jpeg, mjpeg, mp4, rle, v308, v410), h264 \& h265 usage, avc, hevc,
86                 and recently released AV1 and WebP
87             \item raw image format for over 700 supported cameras, courtesy Dave Coffin's DCraw
88         \end{itemize}
89         \item[Standard Features]~\\
90             \begin{itemize}
91                 \item Program window for video and audio tracks, navigation, popups, playing and seeking functions.
92                 \item Editing via track manipulation with either drag and drop editing or cut and paste editing.
93                 \item  Patchbay tools: fader, gang, arm, enable output, expanders, mixers, and blending operations.
94                 \item Undo and Redo capability for many editing functions.
95                 \item Drag handle functionality for Ripple, Roll, Slip, Slide, Edge, and No Effect.
96                 \item Dynamic Keyframe support with curve, toggle, automatic, compositor, and editing capabilities.
97                 \item Proxy editing support to speed up editing for large formatted files on slower computers.
98                 \item Compositor window with masking, zooming, cropping, projector and camera capabilities.
99                 \item Viewing window for quickly viewing/playing audio, video, clips, or proxies.
100                 \item Resources window with Media, Proxy, Clips, Video and Audio Effects/Transitions.
101                 \item User defined bins/folders for a project.
102                 \item Expandable Video/Audio effects for grouping selections such as Color Correction or Motion plugins.
103                 \item Included are over 400 Plugins – audio and video native, FFmpeg, plus expandable to include others.
104                 \item LV2 and Ladspa plugins audio support.
105                 \item Mouse over Media or Proxy folders to get a 5 second real time preview of the media.
106                 \item Single or multiple files rendering; background rendering, batch rendering, command line rendering, and use of a Render Farm to take advantage of multiple computer CPUs.
107                 \item Numerous pre-defined output formats automatically available and allowance for user-defined formats.
108                 \item Capture and Recording capability to include Broadcast TV recording, editing, and viewing.
109                 \item Hundreds of Shortcuts are defined which are easily viewed using the shell commands pulldown.
110                 \item PorterDuff operations are available in the patchbay of the main timeline window for alpha blending.
111                 \item Color correction + 8-bit and 10-bit color space.
112                 \item Up to 8K video supported.
113                 \item ShuttlePro and ShuttleXpress functionality.
114                 \item International language support.
115                 \item Multi-screen, Multi-viewers, Multi-session, Multi-pane capability.
116                 \item Menu bar shell commands with reference to some manuals and user-definable additions.
117                 \item Video stabilization, Motion tracking, Motion Graphics.
118                 \item Blade Cut/Hard Edges, Snap/Cut editing and Snap Dragging.
119                 \item OpenGL support as well as Direct X11 speedup.
120                 \item Advanced Trim Features and Grouping.
121                 \item Asset and Title colors selection including Alpha slider adjustment.
122                 \item Scaling preference for any monitor size and HiDPI to support 4K monitors.
123             \end{itemize}
124             \item[Innovative New Features]~\\
125                 \begin{itemize}
126                     \item Inter-View mode as invented through a collaborative effort by a user and the developer.
127                     \item Proxy settings for large formatted media with the coveted Scalar option and proxy quick switch.  Includes a 1:1 proxy setting used to save CPU time with a reduced bitrate.
128                     \item Multiple cameras / Mixer Viewer with the number of cameras only limited by the resources on the user’s computer (on a large system, 50 are known to work).
129                     \item Audio/Video sync via waveforms, or timecodes to include syncing with externally recorded audio.
130                     \item DVD/bluray creation, editing, and copying for non-commercial media greatly enhanced for usability.
131                     \item Title plugin virtually unlimited script size with many changeable attributes such as size, blink, color.
132                     \item Motion Graphics using the Sketcher plugin to create elements such as ellipses, rectangles and shapes for simpler motion graphics.
133                     \item Open EDL for editing clips, nested clips, and xml files while working on a Project.
134                     \item File by Reference; To be able to modify the original source during editing (which, in this case, becomes destructive).
135                     \item The Vectorscope option in the Videoscope plugin allows for the use of any number of user-supplied grid patterns as an Overlay.
136                     \item Hardware acceleration with vaapi and vdpau for computers with graphics hardware meeting certain criteria.
137                     \item Bump Autos is a new type of keyframe automation that allows you to easily create and manage keyframes intervals in Speed, Fade and Camera/Projector-XYZ curves.
138                 \end{itemize}
139 \end{description}
140
141 \section*{Chapters Overview}%
142 \label{sec:chapters_overview}
143
144 Below is listed a brief overview of each chapter to help you to decide which chapters you should pay the most attention to and read more thoroughly.
145 And which chapters are important for beginning to learn to use \CGG{}. At the end of the descriptions is a list of the sections to read for beginners.
146
147 \begin{description}
148     \item[Chapter~\ref{cha:Installation} ] \nameref{cha:Installation}.
149
150         If you just want to get started using the program, you can safely skip this chapter and instead go to:
151         {\small \url{https://www.cinelerra-gg.org}}
152         and simply download a pre-built linux version for your Operating System. If you would like to do your own builds so that you always have the latest, refer to this chapter to learn how.
153         But if you are already familiar with doing your own builds, you can just refer to this chapter when you encounter issues.
154     \item[Chapter~\ref{cha:the_4_windows} ] \nameref{cha:the_4_windows}.
155
156         It is important to understand the window setup in \CGG{} and what each of them is used for.
157         In addition this chapter covers some basic navigation functions that you will need to know.
158         However, if you have used an NLE before and don’t mind experimenting to learn how to execute certain functions, probably there is no need to peruse this chapter.
159     \item[Chapter~\ref{cha:project_and_media_attributes}] \nameref{cha:project_and_media_attributes}.
160
161         This chapter is helpful for basic understanding of setting up your session but it can easily be skipped.
162
163     \item[Chapter~\ref{cha:load_save_and_the_EDL}] \nameref{cha:load_save_and_the_EDL}.
164
165                 The EDL is the list of changes that \CGG{} would make to the original media in order to produce the desired output
166         Since this is important to not losing your work, you should read this chapter for some basic usage concepts and for some lesser used functions that may come in handy.
167         Besides how to Load and Save files, there is also information on using raw camera formats.
168         Helpful hints on working with image sequences, such as a bunch of pictures from your camera all loaded at once, is a time saver. Understanding that the EDL is the list of changes that would be made to the original media in order to produce the desired output is key to ensuring that that media remains intact.
169         
170     \item[Chapter~\ref{cha:editing}] \nameref{cha:editing}.
171
172         New and occasional users will find it necessary to read this chapter. However, you can decide which editing mode you prefer and concentrate on reading that section.
173         Even seasoned users will want to read this chapter in order to take advantage of features that have been newly implemented or may be less familiar due to infrequent usage.
174         Anyone who wants the editing capabilities that comes with use of the Shuttle Jog Wheel, will initially need to read that section to become familiar with its usage.
175         
176      \item[Chapter~\ref{cha:advanced_editing}] \nameref{cha:advanced_editing}.
177      
178         Many tools for the advanced editing: Proxy, Nesting; Trimming; Multi-Cam; Audio/Video sync and Transcoding. \CGG{} offers many possibilities and sophisticated alternatives for editing, but they are complex tools. Here we deepen their knowledge and use.
179
180     \item[Chapter~\ref{cha:rendering}] \nameref{cha:rendering}.
181
182         Minimally most users will need to read the section on single file rendering to get started; since after all the whole purpose of using an NLE is to create your own media.
183         The end of this chapter includes some helpful specific rendering scenarios which could prove quite useful.
184         You might also want to consider using batch rendering and background rendering for performance reasons.
185         And, of course, render farm usage to take advantage of multiple computers can be a real boost.
186
187     \item[Chapter~\ref{cha:keyframes}] \nameref{cha:keyframes}.
188
189         This is a more advanced topic but extremely useful to know.
190         Keyframes are data values that have been associated to media on the timeline that affect the media presentation.
191         You can go for years without knowing all of the nuances but you will most likely have a need to use and understand them sooner or later.
192
193     \item[Chapter~\ref{cha:ffmpeg_interactions}] \nameref{cha:ffmpeg_interactions}.
194
195         Skip this chapter if you are just getting started. Skip this chapter if you just want to use common
196         formats that are already set up for you. Experts may want to refer to this chapter in order to set up their
197         own option files.
198
199     \item[Chapter~\ref{cha:plugins}]\nameref{cha:plugins}.
200
201         Use this chapter as a reference to add an audio or video plugin in order to correct color or add some fancy effect.
202         You will not want to read about each and every plugin, most of which you will never use.
203         On the other hand, going over the section on “some specific details concerning plugins” might come in handy.
204
205     \item[Chapter~\ref{cha:transition_plugin}] \nameref{cha:transition_plugin}.
206
207         Everyone who does not know about using transitions should read this chapter because you will want to use transitions between cuts in your video for smoothly changing scenes.
208         It is short and easy reading.
209
210     \item[Chapter~\ref{cha:overlays}] \nameref{cha:overlays} Modes, Alpha Blending, and Porter Duff.
211
212         Experts can really use the information in this chapter to spiff up their editing work through some blending type techniques.
213         A lot of information and possibilities are described here.
214
215     \item[Chapter~\ref{cha:capturing_recording_media}] \nameref{cha:capturing_recording_media}.
216
217         This chapter is helpful in learning how to capture and record media from various sources.  A section on using \CGG{} with broadcast TV (NTSC) is especially useful.
218
219     \item[Chapter~\ref{cha:dvd_bluray_creation}] \nameref{cha:dvd_bluray_creation}.
220
221         If this is what you want to do, then read this chapter.
222         In the case of DVD media creation it includes many examples and lots of tips for checking your methods.
223
224     \item[Chapter~\ref{cha:shortcuts}] \nameref{cha:shortcuts}.
225
226         Everyone will want to use this chapter to speed up their editing sessions.
227         Once you find yourself doing the same thing over and over again, you will want to know if there is a shortcut. Then look here!
228
229     \item[Chapter~\ref{cha:configuration_settings_preferences}] \nameref{cha:configuration_settings_preferences}.
230
231         Refer to this chapter when you want to change some setting or preference.
232         Otherwise if a new user, you should make sure to read the first page which includes some important basic information.
233
234     \item[Chapter~\ref{cha:how_stuff_works}] \nameref{cha:how_stuff_works}.
235
236         Only read this chapter if you are confused about a specific covered topic and how it works.
237
238     \item[Chapter~\ref{cha:troubleshooting_help}] \nameref{cha:troubleshooting_help}.
239
240         Use this chapter for diagnosing a problem and find out what to report to get the best resolution or help.
241
242     \item[Chapter~\ref{cha:performance_tips}]  \nameref{cha:performance_tips}.
243
244         There are a few performance tips in this chapter that may eventually prove useful.
245
246     \item[Chapter~\ref{cha:translations}] \nameref{cha:translations}.
247
248         If you want to help by providing translations for a specific language, there is a complete description of how to do this and what to do.
249
250     \item[Chapter~\ref{cha:licenses}] \nameref{cha:licenses}.
251
252     \item[Appendix~\ref{cha:Quickstart}] \nameref{cha:Quickstart}.
253
254         Here you go! If you hate to read, just go over the quick start guide or the youtube video creation and simply be on your way.
255
256     \item[Appendix~\ref{cha:developer's_section}] \nameref{cha:developer's_section}.
257
258         Some extra information that developers may or may not find useful.
259
260     \item[Appendix~\ref{cha:auxiliary_programs}] \nameref{cha:auxiliary_programs}.
261
262         This is a catch-all for any useful programs that may need to be included, mostly for analysis.
263         
264      \item[Appendix~\ref{cha:editing_real_world_usage}] \nameref{cha:editing_real_world_usage}.
265     
266         Our users illustrate in-depth examples of their workflows by showing their editing in real use cases.
267
268 \end{description}
269
270 In summary, \textit{must} reads for a new user would be these chapters or sections:
271
272 \begin{itemize}
273     \item Chapter~\ref{cha:the_4_windows} --- \nameref{cha:the_4_windows}.
274     \item Chapter~\ref{cha:load_save_and_the_EDL} --- \nameref{cha:load_save_and_the_EDL}.
275     \item Chapter~\ref{cha:editing} --- \nameref{cha:editing}; read all sections except emphasize only either \nameref{sec:cut_paste_editing} or \nameref{sec:drag_drop_editing} to suit your purpose and then skim the editing mode that is not your preference as some operations work in either mode.
276         Skip the \nameref{sec:shuttle_jog_wheels_editing} section unless you have this jog wheel in hand.
277     \item Chapter~\ref{cha:rendering} --- \nameref{cha:rendering}; minimally read the \nameref{sec:single_file_rendering} section.
278     \item Chapter~\ref{cha:plugins} --- \nameref{cha:plugins}; read the section on \nameref{sec:how_use_plugins}.
279     \item Chapter~\ref{cha:transition_plugin} --- \nameref{cha:transition_plugin}.
280     \item Chapter~\ref{cha:configuration_settings_preferences} --- \nameref{cha:configuration_settings_preferences}; read at least the first couple of paragraphs.
281 \end{itemize}
282
283 %%% Local Variables:
284 %%% mode: latex
285 %%% TeX-master: "../CinelerraGG_Manual"
286 %%% End: