mirror of
				https://github.com/amiaopensource/ffmprovisr.git
				synced 2025-10-26 06:32:06 +01:00 
			
		
		
		
	Compare commits
	
		
			27 Commits
		
	
	
		
			v2017-04-1
			...
			v2017-04-1
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | b2a04d138f | ||
|  | b53f6c9984 | ||
|  | 64a362314c | ||
|  | 2a71179776 | ||
|  | 77e346c067 | ||
|  | b995fb05c5 | ||
|  | d30741e378 | ||
|  | e3b01e2aa8 | ||
|  | 750a763157 | ||
|  | 0a6e5a4a7a | ||
|  | 54a8ab6057 | ||
|  | e762c7dc42 | ||
|  | cb7f001444 | ||
|  | 89039f55b3 | ||
|  | 59e6c6d879 | ||
|  | 195bc5446e | ||
|  | a1cc5a4428 | ||
|  | 58663a869f | ||
|  | 05d16367f0 | ||
|  | 9477bcfe0a | ||
|  | ad439d3b78 | ||
|  | 736b01e426 | ||
|  | 57166fe61d | ||
|  | ec26d2038a | ||
|  | 321d998b5a | ||
|  | 009670eed1 | ||
|  | d3a941a725 | 
							
								
								
									
										75
									
								
								index.html
									
									
									
									
									
								
							
							
						
						
									
										75
									
								
								index.html
									
									
									
									
									
								
							| @@ -30,12 +30,12 @@ | |||||||
|   <p>For instructions on how to install FFmpeg on Mac, Linux, and Windows, refer to Reto Kromer’s <a href="https://avpres.net/FFmpeg/#ch1" target="_blank">installation instructions</a>.</p> |   <p>For instructions on how to install FFmpeg on Mac, Linux, and Windows, refer to Reto Kromer’s <a href="https://avpres.net/FFmpeg/#ch1" target="_blank">installation instructions</a>.</p> | ||||||
|   <p>For Bash and command line basics, try the <a href="https://learnpythonthehardway.org/book/appendixa.html" target="_blank">Command Line Crash Course</a>. For a little more context presented in an ffmprovisr style, try <a href="http://explainshell.com/" target="_blank">explainshell.com</a>!</p> |   <p>For Bash and command line basics, try the <a href="https://learnpythonthehardway.org/book/appendixa.html" target="_blank">Command Line Crash Course</a>. For a little more context presented in an ffmprovisr style, try <a href="http://explainshell.com/" target="_blank">explainshell.com</a>!</p> | ||||||
|   <h5>License</h5> |   <h5>License</h5> | ||||||
|   <p><a target="_blank" href="https://creativecommons.org/licenses/by-sa/4.0/"><img alt="Creative Commons License" src="https://i.creativecommons.org/l/by-sa/4.0/88x31.png"></a><br> |   <p><a href="https://creativecommons.org/licenses/by-sa/4.0/" target="_blank"><img alt="Creative Commons License" src="https://i.creativecommons.org/l/by-sa/4.0/88x31.png"></a><br> | ||||||
|     This work is licensed under a <a href="https://creativecommons.org/licenses/by-sa/4.0/">Creative Commons Attribution-ShareAlike 4.0 International License</a>.</p> |     This work is licensed under a <a href="https://creativecommons.org/licenses/by-sa/4.0/" target="_blank">Creative Commons Attribution-ShareAlike 4.0 International License</a>.</p> | ||||||
|   <h5>Sister projects</h5> |   <h5>Sister projects</h5> | ||||||
|   <p><a target="_blank" href="http://dd388.github.io/crals/">Script Ahoy</a>: Community Resource for Archivists and Librarians Scripting</p> |   <p><a href="http://dd388.github.io/crals/" target="_blank">Script Ahoy</a>: Community Resource for Archivists and Librarians Scripting</p> | ||||||
|   <p><a target="_blank" href="https://datapraxis.github.io/sourcecaster/">The Sourcecaster</a>: an app that helps you use the command line to work through common challenges that come up when working with digital primary sources.</p> |   <p><a href="https://datapraxis.github.io/sourcecaster/" target="_blank">The Sourcecaster</a>: an app that helps you use the command line to work through common challenges that come up when working with digital primary sources.</p> | ||||||
|   <p><a target="_blank" href="https://amiaopensource.github.io/cable-bible/">Cable Bible</a>: A Guide to Cables and Connectors Used for Audiovisual Tech</p> |   <p><a href="https://amiaopensource.github.io/cable-bible/" target="_blank">Cable Bible</a>: A Guide to Cables and Connectors Used for Audiovisual Tech</p> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
| <div class="well col-md-8 col-md-offset-0"> | <div class="well col-md-8 col-md-offset-0"> | ||||||
| @@ -599,15 +599,15 @@ | |||||||
|         <div class="well"> |         <div class="well"> | ||||||
|           <h3>Inverse telecine a video file</h3> |           <h3>Inverse telecine a video file</h3> | ||||||
|           <p><code>ffmpeg -i <i>input_file</i> -c:v libx264 -vf "fieldmatch,yadif,decimate" <i>output_file</i></code></p> |           <p><code>ffmpeg -i <i>input_file</i> -c:v libx264 -vf "fieldmatch,yadif,decimate" <i>output_file</i></code></p> | ||||||
|           <p>The inverse telecine procedure reverses the <a href="https://en.wikipedia.org/wiki/Three-two_pull_down">3:2 pull down</a> process, restoring 29.97fps interlaced video to the 24fps frame rate of the original film source.</p> |           <p>The inverse telecine procedure reverses the <a href="https://en.wikipedia.org/wiki/Three-two_pull_down" target="_blank">3:2 pull down</a> process, restoring 29.97fps interlaced video to the 24fps frame rate of the original film source.</p> | ||||||
|           <dl> |           <dl> | ||||||
|             <dt>ffmpeg</dt><dd>starts the command</dd> |             <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|             <dt>-i <i>input file</i></dt><dd>path, name and extension of the input file</dd> |             <dt>-i <i>input file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|             <dt>-c:v libx264</dt><dd>encode video as H.264</dd> |             <dt>-c:v libx264</dt><dd>encode video as H.264</dd> | ||||||
|             <dt>-vf "fieldmatch,yadif,decimate"</dt><dd>applies these three video filters to the input video.<br> |             <dt>-vf "fieldmatch,yadif,decimate"</dt><dd>applies these three video filters to the input video.<br> | ||||||
|             <a href="https://ffmpeg.org/ffmpeg-filters.html#fieldmatch">Fieldmatch</a> is a field matching filter for inverse telecine - it reconstructs the progressive frames from a telecined stream.<br> |             <a href="https://ffmpeg.org/ffmpeg-filters.html#fieldmatch" target="_blank">Fieldmatch</a> is a field matching filter for inverse telecine - it reconstructs the progressive frames from a telecined stream.<br> | ||||||
|             <a href="https://ffmpeg.org/ffmpeg-filters.html#yadif-1">Yadif</a> (‘yet another deinterlacing filter’) deinterlaces the video. (Note that ffmpeg also includes several other deinterlacers).<br> |             <a href="https://ffmpeg.org/ffmpeg-filters.html#yadif-1" target="_blank">Yadif</a> (‘yet another deinterlacing filter’) deinterlaces the video. (Note that ffmpeg also includes several other deinterlacers).<br> | ||||||
|             <a href="https://ffmpeg.org/ffmpeg-filters.html#decimate-1">Decimate</a> deletes duplicated frames.</dd> |             <a href="https://ffmpeg.org/ffmpeg-filters.html#decimate-1" target="_blank">Decimate</a> deletes duplicated frames.</dd> | ||||||
|             <dt><i>output file</i></dt><dd>path, name and extension of the output file</dd> |             <dt><i>output file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|           </dl> |           </dl> | ||||||
|           <p><code>"fieldmatch,yadif,decimate"</code> is an ffmpeg <a href="https://trac.ffmpeg.org/wiki/FilteringGuide#FiltergraphChainFilterrelationship" target="_blank">filtergraph</a>. Here the filtergraph is made up of one filter chain, which is itself made up of the three filters (separated by commas).<br> |           <p><code>"fieldmatch,yadif,decimate"</code> is an ffmpeg <a href="https://trac.ffmpeg.org/wiki/FilteringGuide#FiltergraphChainFilterrelationship" target="_blank">filtergraph</a>. Here the filtergraph is made up of one filter chain, which is itself made up of the three filters (separated by commas).<br> | ||||||
| @@ -1172,7 +1172,7 @@ foreach ($file in $inputfiles) { | |||||||
|             <dt>-an</dt><dd>ignores the audio stream (audio no)</dd> |             <dt>-an</dt><dd>ignores the audio stream (audio no)</dd> | ||||||
|             <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> |             <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|           </dl> |           </dl> | ||||||
|           <p>You may verify an MD5 checksum file created this way by using a <a href="check_framemd5.sh" target="_blank">Bash script</a>.</p> |           <p>You may verify an MD5 checksum file created this way by using a <a href="scripts/check_video_framemd5.sh" target="_blank">Bash script</a>.</p> | ||||||
|           <p class="link"></p> |           <p class="link"></p> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
| @@ -1187,13 +1187,14 @@ foreach ($file in $inputfiles) { | |||||||
|       <div class="modal-content"> |       <div class="modal-content"> | ||||||
|         <div class="well"> |         <div class="well"> | ||||||
|           <h3>Create MD5 checksums (audio samples)</h3> |           <h3>Create MD5 checksums (audio samples)</h3> | ||||||
|           <p><code>ffmpeg -i <i>input_file</i> -filter_complex "asetnsamples=<i>n=48000</i>" -f framemd5 -vn <i>output_file</i></code></p> |           <p><code>ffmpeg -i <i>input_file</i> -af "asetnsamples=<i>n=48000</i>" -f framemd5 -vn <i>output_file</i></code></p> | ||||||
|           <p>This will create an MD5 checksum for each group of 48000 audio samples.<br> The number of samples per group can be set arbitrarily, but it's good practice to match the samplerate of the media file (so you will get one checksum per second).</p> |           <p>This will create an MD5 checksum for each group of 48000 audio samples.<br> The number of samples per group can be set arbitrarily, but it's good practice to match the samplerate of the media file (so you will get one checksum per second).</p> | ||||||
|           <p>Examples for other samplerates:</p> |           <p>Examples for other samplerates:</p> | ||||||
|           <ul> |           <ul> | ||||||
|             <li>44.1 kHz: "asetnsamples=n=44100"</li> |             <li>44.1 kHz: "asetnsamples=n=44100"</li> | ||||||
|             <li>96 kHz: "asetnsamples=n=96000"</li> |             <li>96 kHz: "asetnsamples=n=96000"</li> | ||||||
|           </ul> |           </ul> | ||||||
|  |           <p>Note: This filter trandscodes audio to 16 bit PCM by default. The generated framemd5s will represent this value. Validating these framemd5s will require using the same default settings.</p> | ||||||
|           <dl> |           <dl> | ||||||
|             <dt>ffmpeg</dt><dd>starts the command</dd> |             <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|             <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> |             <dt>-i <i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
| @@ -1201,7 +1202,7 @@ foreach ($file in $inputfiles) { | |||||||
|             <dt>-vn</dt><dd>ignores the video stream (video no)</dd> |             <dt>-vn</dt><dd>ignores the video stream (video no)</dd> | ||||||
|             <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> |             <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|           </dl> |           </dl> | ||||||
|           <p>You may verify an MD5 checksum file created this way by using a <a href="check_framemd5.sh" target="_blank">Bash script</a>.</p> |           <p>You may verify an MD5 checksum file created this way by using a <a href="scripts/check_audio_framemd5.sh" target="_blank">Bash script</a>.</p> | ||||||
|           <p class="link"></p> |           <p class="link"></p> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
| @@ -1468,7 +1469,7 @@ foreach ($file in $inputfiles) { | |||||||
|           <dl> |           <dl> | ||||||
|             <dt>ffmpeg</dt><dd>starts the command</dd> |             <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|             <dt>-i <i>input_file</i></dt><dd>takes in a normal file</dd> |             <dt>-i <i>input_file</i></dt><dd>takes in a normal file</dd> | ||||||
|             <dt>-bsf noise=1</dt><dd>sets bitstream filters for all to 'noise'. Filters can be set on specific filters using syntax such as <code>-bsf:v</code> for video, <code>-bsf:a</code> for audio, etc. The <a target="_blank" href="https://www.ffmpeg.org/ffmpeg-bitstream-filters.html#noise">noise filter</a> intentionally damages the contents of packets without damaging the container. This sets the noise level to 1 but it could be left blank or any number above 0.</dd> |             <dt>-bsf noise=1</dt><dd>sets bitstream filters for all to 'noise'. Filters can be set on specific filters using syntax such as <code>-bsf:v</code> for video, <code>-bsf:a</code> for audio, etc. The <a href="https://www.ffmpeg.org/ffmpeg-bitstream-filters.html#noise" target="_blank">noise filter</a> intentionally damages the contents of packets without damaging the container. This sets the noise level to 1 but it could be left blank or any number above 0.</dd> | ||||||
|             <dt>-c copy</dt><dd>use stream copy mode to re-mux instead of re-encode</dd> |             <dt>-c copy</dt><dd>use stream copy mode to re-mux instead of re-encode</dd> | ||||||
|             <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> |             <dt><i>output_file</i></dt><dd>path, name and extension of the output file</dd> | ||||||
|           </dl> |           </dl> | ||||||
| @@ -1519,7 +1520,7 @@ foreach ($file in $inputfiles) { | |||||||
|             <dt>-i "sine=frequency=1000:sample_rate=48000"</dt><dd>Sets the signal to 1000 Hz, sampling at 48 kHz.</dd> |             <dt>-i "sine=frequency=1000:sample_rate=48000"</dt><dd>Sets the signal to 1000 Hz, sampling at 48 kHz.</dd> | ||||||
|             <dt>-c:a pcm_s16le</dt><dd>encodes the audio codec in <code>pcm_s16le</code> (the default encoding for wav files). pcm represents pulse-code modulation format (raw bytes), <code>16</code> means 16 bits per sample, and <code>le</code> means "little endian"</dd> |             <dt>-c:a pcm_s16le</dt><dd>encodes the audio codec in <code>pcm_s16le</code> (the default encoding for wav files). pcm represents pulse-code modulation format (raw bytes), <code>16</code> means 16 bits per sample, and <code>le</code> means "little endian"</dd> | ||||||
|             <dt>-t 10</dt><dd>specifies recording time of 10 seconds</dd> |             <dt>-t 10</dt><dd>specifies recording time of 10 seconds</dd> | ||||||
|             <dt>-c:v <i>ffv1</i></dt><dd>Encodes to <a href="https://en.wikipedia.org/wiki/FFV1">FFV1</a>. Alter this setting to set your desired codec.</dd> |             <dt>-c:v <i>ffv1</i></dt><dd>Encodes to <a href="https://en.wikipedia.org/wiki/FFV1" target="_blank">FFV1</a>. Alter this setting to set your desired codec.</dd> | ||||||
|             <dt><i>output_file</i>.wav</dt><dd>path, name and extension of the output file</dd> |             <dt><i>output_file</i>.wav</dt><dd>path, name and extension of the output file</dd> | ||||||
|           </dl> |           </dl> | ||||||
|           <p class="link"></p> |           <p class="link"></p> | ||||||
| @@ -1946,6 +1947,50 @@ e.g.: <code>ffmpeg -f concat -safe 0 -i mylist.txt -c copy <i>output_file</i></c | |||||||
|   </div> |   </div> | ||||||
|   <!-- ends View Format info --> |   <!-- ends View Format info --> | ||||||
|  |  | ||||||
|  |   <!-- Compare Video Fingerprints --> | ||||||
|  |   <span data-toggle="modal" data-target="#compare_video_fingerprints"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Compare Video Fingerprints">Compare Video Fingerprints</button></span> | ||||||
|  |   <div id="compare_video_fingerprints" class="modal fade" tabindex="-1" role="dialog"> | ||||||
|  |     <div class="modal-dialog modal-lg"> | ||||||
|  |       <div class="modal-content"> | ||||||
|  |         <div class="well"> | ||||||
|  |           <h3>Compare two video files for content similarity using perceptual hashing</h3> | ||||||
|  |           <p><code>ffmpeg -i <i>input_one</i> -i <i>input_two</i> -filter_complex signature=detectmode=full:nb_inputs=2 -f null -</code></p> | ||||||
|  |           <dl> | ||||||
|  |             <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|  |             <dt>-i <i>input_one</i> -i <i>input_two</i></dt><dd>assigns the input files</dd> | ||||||
|  |             <dt>-filter_complex</dt><dd>enables using more than one input file to the filter</dd> | ||||||
|  |             <dt>signature=detectmode=full</dt><dd>Applies the signature filter to the inputs in 'full' mode. The other option is 'fast'.</dd> | ||||||
|  |             <dt>nb_inputs=2</dt><dd>tells the filter to expect two input files</dd> | ||||||
|  |             <dt>-f null -</dt><dd>Sets the output of ffmpeg to a null stream (since we are not creating a transcoded file, just viewing metadata).</dd> | ||||||
|  |           </dl> | ||||||
|  |           <p class="link"></p> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <!-- ends Compare Video Fingerprints --> | ||||||
|  |  | ||||||
|  |   <!-- Generate Video Fingerprint --> | ||||||
|  |   <span data-toggle="modal" data-target="#generate_video_fingerprint"><button type="button" class="btn btn-default" data-toggle="tooltip" data-placement="bottom" title="Generate Video Fingerprint">Generate Video Fingerprint</button></span> | ||||||
|  |   <div id="generate_video_fingerprint" class="modal fade" tabindex="-1" role="dialog"> | ||||||
|  |     <div class="modal-dialog modal-lg"> | ||||||
|  |       <div class="modal-content"> | ||||||
|  |         <div class="well"> | ||||||
|  |           <h3>Generate a perceptual hash for an input video file</h3> | ||||||
|  |           <p><code>ffmpeg -i <i>input</i> -vf signature=format=xml:filename="output.xml" -an -f null -</code></p> | ||||||
|  |           <dl> | ||||||
|  |             <dt>ffmpeg -i <i>input</i></dt><dd>starts the command using your input file</dd> | ||||||
|  |             <dt>-vf signature=format=xml</dt><dd>applies the signature filter to the input file and sets the output format for the fingerprint to xml</dd> | ||||||
|  |             <dt>filename="output.xml"</dt><dd>sets the output for the signature filter</dd> | ||||||
|  |             <dt>-an</dt><dd>tells ffmpeg to ignore the audio stream of the input file</dd> | ||||||
|  |             <dt>-f null -</dt><dd>Sets the ffmpeg output to a null stream (since we are only interested in the output generated by the filter).</dd> | ||||||
|  |           </dl> | ||||||
|  |           <p class="link"></p> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <!-- ends Generate Video Fingerprint --> | ||||||
|   </div><!-- closes the well --> |   </div><!-- closes the well --> | ||||||
|  |  | ||||||
|   <div class="well"> |   <div class="well"> | ||||||
| @@ -1963,7 +2008,7 @@ e.g.: <code>ffmpeg -f concat -safe 0 -i mylist.txt -c copy <i>output_file</i></c | |||||||
|             <dt>ffmpeg</dt><dd>starts the command</dd> |             <dt>ffmpeg</dt><dd>starts the command</dd> | ||||||
|             <dt><i>input_file</i></dt><dd>path, name and extension of the input file</dd> |             <dt><i>input_file</i></dt><dd>path, name and extension of the input file</dd> | ||||||
|             <dt>-c:v copy</dt><dd>Copy all mapped video streams.</dd> |             <dt>-c:v copy</dt><dd>Copy all mapped video streams.</dd> | ||||||
|             <dt>-c:a pcm_s16le</dt><dd>Tells ffmpeg to encode the audio stream in 16-bit linear PCM (<a href="https://en.wikipedia.org/wiki/Endianness#Little-endian">little endian</a>)</dd> |             <dt>-c:a pcm_s16le</dt><dd>Tells ffmpeg to encode the audio stream in 16-bit linear PCM (<a href="https://en.wikipedia.org/wiki/Endianness#Little-endian" target="_blank">little endian</a>)</dd> | ||||||
|             <dt>-af "aresample=async=1000"</dt><dd>Stretch/squeezes samples to given timestamps, with maximum of 1000 samples per second compensation <a href="https://ffmpeg.org/ffmpeg-filters.html#aresample-1" target="_blank">[more]</a></dd> |             <dt>-af "aresample=async=1000"</dt><dd>Stretch/squeezes samples to given timestamps, with maximum of 1000 samples per second compensation <a href="https://ffmpeg.org/ffmpeg-filters.html#aresample-1" target="_blank">[more]</a></dd> | ||||||
|             <dt><i>output_file</i></dt><dd>path, name and extension of the output file. Try different file extensions such as mkv, mov, mp4, or avi.</dd> |             <dt><i>output_file</i></dt><dd>path, name and extension of the output file. Try different file extensions such as mkv, mov, mp4, or avi.</dd> | ||||||
|           </dl> |           </dl> | ||||||
|   | |||||||
							
								
								
									
										38
									
								
								readme.md
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								readme.md
									
									
									
									
									
								
							| @@ -1,33 +1,41 @@ | |||||||
| # [ffmprovisr](http://amiaopensource.github.io/ffmprovisr) | # [ffmprovisr](http://amiaopensource.github.io/ffmprovisr) | ||||||
|  |  | ||||||
| Repository of useful FFmpeg command lines for archivists! [AMIA hackday](http://wiki.curatecamp.org/index.php/Association_of_Moving_Image_Archivists_%26_Digital_Library_Federation_Hack_Day_2015) edition. | Repository of useful FFmpeg command lines for archivists! | ||||||
|  |  | ||||||
| ## What is this? | ## What is this? | ||||||
|  |  | ||||||
| Project Objective: To facilitate better understanding of FFmpeg through collaborative sharing of useful scripts and detailed flag-level description of how each script works so archivists can copy-paste and produce their own scripts but also understand how and why they work. | #### Project Objective | ||||||
|  |  | ||||||
|  | To facilitate better understanding of FFmpeg through collaborative sharing of useful scripts and detailed flag-level description of how each script works, so archivists can copy-paste and produce their own scripts, but also understand how and why they work. | ||||||
|  |  | ||||||
| ## How do I see it? | ## How do I see it? | ||||||
|  |  | ||||||
| Code stuff in the gh-pages branch (the default primary branch). Readme is right here. The site is live and lives on github pages. You can see it [here](http://amiaopensource.github.io/ffmprovisr), or you can download a [release](https://github.com/amiaopensource/ffmprovisr/releases) and use it locally. | The code is found in the gh-pages branch (the default primary branch). Readme is right here. You can see the site live on [GitHub pages](http://amiaopensource.github.io/ffmprovisr), or you can download a [release](https://github.com/amiaopensource/ffmprovisr/releases) and use it locally. | ||||||
|  |  | ||||||
| ## How do I contribute? | ## How do I contribute? | ||||||
|  |  | ||||||
| You are welcome to edit the codebase yourself or just supply the information and ask it to be added to the site. | You are welcome to edit the codebase yourself, or just supply the information and ask it to be added to the site. | ||||||
|  |  | ||||||
| To contribute to this project directly (and more quickly), clone this repository and create a new branch (`git checkout -b your-branch-name`) and add or modify a new block in index.html. Then submit a pull request and someone can review and integrate your code. There is a commented-out sample available at the bottom of index.html that can be used to build your own block. | #### Edit codebase | ||||||
|  |  | ||||||
| If you are having trouble with the coding it yourself or with github, feel free to [submit an issue](https://github.com/amiaopensource/ffmprovisr/issues) with the kind of command you would like to see added to the site. | To contribute to this project directly (and more quickly), clone this repository and create a new branch (`git checkout -b your-branch-name`) and add or modify a new block in `index.html`. Then [submit a pull request](https://github.com/amiaopensource/ffmprovisr/pulls) and the maintainers will review and integrate your code. There is a commented-out sample block available at the bottom of `index.html` that can be as a guideline for your command. | ||||||
|  |  | ||||||
|  | #### Make a request | ||||||
|  |  | ||||||
|  | If you are having trouble with coding it yourself or with github, feel free to [submit an issue](https://github.com/amiaopensource/ffmprovisr/issues) with the kind of command you would like to see added to the site. | ||||||
|  |  | ||||||
|  | #### General help | ||||||
|  |  | ||||||
| If you want to help but don't have a new script to add, you can help us by testing out the scripts available, by refining or clarifying the documentation, or [creating an issue](https://github.com/amiaopensource/ffmprovisr/issues) for anything that sounds confusing and requires clarification. | If you want to help but don't have a new script to add, you can help us by testing out the scripts available, by refining or clarifying the documentation, or [creating an issue](https://github.com/amiaopensource/ffmprovisr/issues) for anything that sounds confusing and requires clarification. | ||||||
|  |  | ||||||
| ## License |  | ||||||
|  |  | ||||||
| <a rel="license" href="http://creativecommons.org/licenses/by/4.0/"><img alt="Creative Commons License" style="border-width:0" src="https://i.creativecommons.org/l/by/4.0/80x15.png" /></a><br />This <span xmlns:dct="http://purl.org/dc/terms/" href="http://purl.org/dc/dcmitype/InteractiveResource" rel="dct:type">work</span> by <a xmlns:cc="http://creativecommons.org/ns#" href="http://amiaopensource.github.io/ffmprovisr/" property="cc:attributionName" rel="cc:attributionURL">ffmprovisr</a> is licensed under a <a rel="license" href="http://creativecommons.org/licenses/by/4.0/">Creative Commons Attribution 4.0 International License</a>.<br />Based on a work at <a xmlns:dct="http://purl.org/dc/terms/" href="https://github.com/amiaopensource/ffmprovisr" rel="dct:source">https://github.com/amiaopensource/ffmprovisr</a>. |  | ||||||
|  |  | ||||||
| ## Code of Conduct | ## Code of Conduct | ||||||
|  |  | ||||||
| You can read our contributor code of conduct [here](https://github.com/amiaopensource/ffmprovisr/blob/gh-pages/code_of_conduct.md). | You can read our contributor code of conduct [here](https://github.com/amiaopensource/ffmprovisr/blob/gh-pages/code_of_conduct.md). | ||||||
|  |  | ||||||
|  | ## Maintainers | ||||||
|  |  | ||||||
|  | [Ashley Blewer](https://github.com/ablwr), [Katherine Frances Nagels](https://github.com/kfrn), [Kieran O'Leary](https://github.com/kieranjol) and [Reto Kromer](https://github.com/retokromer) | ||||||
|  |  | ||||||
| ## Contributors | ## Contributors | ||||||
| * Gathered using [octohatrack](https://github.com/LABHR/octohatrack) | * Gathered using [octohatrack](https://github.com/LABHR/octohatrack) | ||||||
|  |  | ||||||
| @@ -68,11 +76,17 @@ Repo: amiaopensource/ffmprovisr | |||||||
| GitHub Contributors: 11   | GitHub Contributors: 11   | ||||||
| All Contributors: 18   | All Contributors: 18   | ||||||
|  |  | ||||||
| ## AVHack Team: | ## AVHack Team | ||||||
|  |  | ||||||
| [Ashley Blewer](https://github.com/ablwr), Eddy Colloton, Rebecca Dillmeier, [Jonathan Farbowitz](https://github.com/jfarbowitz), Rebecca Fraimow, Samuel Gutterman, Kelly Haydon, [Reto Kromer](https://github.com/retokromer), Nicole Martin, [Katherine Frances Nagels](https://github.com/kfrn), [Kieran O'Leary](https://github.com/kieranjol), Catriona Schlosser, Ben Turkus | [Association of Moving Image Archivists & Digital Library Federation Hack Day 2015](http://wiki.curatecamp.org/index.php/Association_of_Moving_Image_Archivists_%26_Digital_Library_Federation_Hack_Day_2015) | ||||||
|  |  | ||||||
|  | [Ashley Blewer](https://github.com/ablwr), [Eddy Colloton](https://github.com/eddycolloton), Rebecca Dillmeier, [Jonathan Farbowitz](https://github.com/jfarbowitz), [Rebecca Fraimow](https://github.com/rfraimow), Samuel Gutterman, [Kelly Haydon](https://github.com/kellyhaydon), [Reto Kromer](https://github.com/retokromer), Nicole Martin, [Katherine Frances Nagels](https://github.com/kfrn), [Kieran O'Leary](https://github.com/kieranjol), Catriona Schlosser, [Ben Turkus](https://github.com/bturkus) | ||||||
|  |  | ||||||
| ## Sister projects | ## Sister projects | ||||||
|  |  | ||||||
| [Script Ahoy](http://dd388.github.io/crals/): Community Resource for Archivists and Librarians Scripting   | [Script Ahoy](http://dd388.github.io/crals/): Community Resource for Archivists and Librarians Scripting   | ||||||
| [sourcecaster](https://datapraxis.github.io/sourcecaster/): helps you use the command line to work through common challenges that come up when working with digital primary sources. | [sourcecaster](https://datapraxis.github.io/sourcecaster/): helps you use the command line to work through common challenges that come up when working with digital primary sources. | ||||||
|  |  | ||||||
|  | ## License | ||||||
|  |  | ||||||
|  | <a rel="license" href="http://creativecommons.org/licenses/by/4.0/"><img alt="Creative Commons License" style="border-width:0" src="https://i.creativecommons.org/l/by/4.0/80x15.png" /></a><br />This <span xmlns:dct="http://purl.org/dc/terms/" href="http://purl.org/dc/dcmitype/InteractiveResource" rel="dct:type">work</span> by <a xmlns:cc="http://creativecommons.org/ns#" href="http://amiaopensource.github.io/ffmprovisr/" property="cc:attributionName" rel="cc:attributionURL">ffmprovisr</a> is licensed under a <a rel="license" href="http://creativecommons.org/licenses/by/4.0/">Creative Commons Attribution 4.0 International License</a>.<br />Based on a work at <a xmlns:dct="http://purl.org/dc/terms/" href="https://github.com/amiaopensource/ffmprovisr" rel="dct:source">https://github.com/amiaopensource/ffmprovisr</a>. | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								check_framemd5.sh → scripts/check_audio_framemd5.sh
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										23
									
								
								check_framemd5.sh → scripts/check_audio_framemd5.sh
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| #!/usr/bin/env bash | #!/usr/bin/env bash | ||||||
|   SCRIPT=$(basename "${0}") |   SCRIPT=$(basename "${0}") | ||||||
|  VERSION='2016-12-31' |  VERSION='2017-04-17' | ||||||
|   AUTHOR='ffmprovisr' |   AUTHOR='ffmprovisr' | ||||||
|      RED='\033[1;31m' |      RED='\033[1;31m' | ||||||
|     BLUE='\033[1;34m' |     BLUE='\033[1;34m' | ||||||
| @@ -13,7 +13,7 @@ fi | |||||||
| 
 | 
 | ||||||
| _output_prompt(){ | _output_prompt(){ | ||||||
|     cat <<EOF |     cat <<EOF | ||||||
| Usage: ${SCRIPT} [-h] | [ -i <av_file> -m <md5_file> ] | Usage: ${SCRIPT} -h | -i <av_file> -m <md5_file> | ||||||
| EOF | EOF | ||||||
|     exit 1 |     exit 1 | ||||||
| } | } | ||||||
| @@ -32,7 +32,7 @@ Dependency: | |||||||
|   ffmpeg |   ffmpeg | ||||||
| About: | About: | ||||||
|   Version: ${VERSION} |   Version: ${VERSION} | ||||||
|   Website: https://github.com/amiaopensource/ffmprovisr/blob/gh-pages/check_framemd5.sh |   Website: https://github.com/amiaopensource/ffmprovisr/blob/gh-pages/scripts/check_audio_framemd5.sh | ||||||
| EOF | EOF | ||||||
|     exit 0 |     exit 0 | ||||||
| } | } | ||||||
| @@ -54,21 +54,24 @@ done | |||||||
| echo -e "${BLUE}Please wait...${NC}" | echo -e "${BLUE}Please wait...${NC}" | ||||||
| unset md5_tmp | unset md5_tmp | ||||||
| if [[ $OSTYPE = "cygwin" ]]; then | if [[ $OSTYPE = "cygwin" ]]; then | ||||||
|     md5_tmp=""${USERPROFILE}/$(basename ${input_hash}).tmp"" |     md5_tmp="${USERPROFILE}/$(basename "${input_hash}").tmp" | ||||||
| else | else | ||||||
|     md5_tmp="${HOME}/$(basename ${input_hash}).tmp" |     md5_tmp="${HOME}/$(basename "${input_hash}").tmp" | ||||||
| fi | fi | ||||||
| $(ffmpeg -i ${input_file} -loglevel 0 -f framemd5 -an ${md5_tmp}) | # Find audio frame size for hash calculation | ||||||
|  | sample_rate=$(grep -v '^#' "${input_hash}" | head -n 1 | tr -d ' ' | cut -d',' -f4) | ||||||
|  | ffmpeg -i "${input_file}" -loglevel 0 -af "asetnsamples=n='$sample_rate'" -f framemd5 -vn "${md5_tmp}" | ||||||
| [[ ! -f ${md5_tmp} ]] && { echo -e "${RED}Error: '${input_file}' is not a valid audio-visual file.${NC}" ; _output_prompt ; } | [[ ! -f ${md5_tmp} ]] && { echo -e "${RED}Error: '${input_file}' is not a valid audio-visual file.${NC}" ; _output_prompt ; } | ||||||
| unset old_file | unset old_file | ||||||
| unset tmp_file | unset tmp_file | ||||||
| old_file=$(grep -v '^#' ${input_hash}) | unset sample_rate | ||||||
| tmp_file=$(grep -v '^#' ${md5_tmp}) | old_file=$(grep -v '^#' "${input_hash}") | ||||||
|  | tmp_file=$(grep -v '^#' "${md5_tmp}") | ||||||
| if [[ "${old_file}" = "${tmp_file}" ]]; then | if [[ "${old_file}" = "${tmp_file}" ]]; then | ||||||
|     echo -e "${BLUE}'$(basename ${input_file})' matches '$(basename ${input_hash})'${NC}" |     echo -e "${BLUE}'$(basename "${input_file}")' matches '$(basename "${input_hash}")'${NC}" | ||||||
|     rm "${md5_tmp}" |     rm "${md5_tmp}" | ||||||
| else | else | ||||||
|     echo -e "${RED}The following differences were detected between '$(basename ${input_file})' and '$(basename ${input_hash})':${NC}" |     echo -e "${RED}The following differences were detected between '$(basename "${input_file}")' and '$(basename "${input_hash}")':${NC}" | ||||||
|     diff "${input_hash}" "${md5_tmp}" |     diff "${input_hash}" "${md5_tmp}" | ||||||
|     rm "${md5_tmp}" |     rm "${md5_tmp}" | ||||||
| fi | fi | ||||||
							
								
								
									
										74
									
								
								scripts/check_video_framemd5.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								scripts/check_video_framemd5.sh
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,74 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  |   SCRIPT=$(basename "${0}") | ||||||
|  |  VERSION='2017-04-17' | ||||||
|  |   AUTHOR='ffmprovisr' | ||||||
|  |      RED='\033[1;31m' | ||||||
|  |     BLUE='\033[1;34m' | ||||||
|  |       NC='\033[0m' | ||||||
|  |  | ||||||
|  | if [[ ${OSTYPE} = "cygwin" ]] || [ ! $(which diff) ]; then | ||||||
|  |     echo -e "${RED}Error: 'diff' is not installed by default. Please install 'diffutils' from Cygwin.${NC}" | ||||||
|  |     exit 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | _output_prompt(){ | ||||||
|  |     cat <<EOF | ||||||
|  | Usage: ${SCRIPT} -h | -i <av_file> -m <md5_file> | ||||||
|  | EOF | ||||||
|  |     exit 1 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | _output_help(){ | ||||||
|  |     cat <<EOF | ||||||
|  | Syntax: | ||||||
|  |   ${SCRIPT} | ||||||
|  |     Prompts a short help message. | ||||||
|  |   ${SCRIPT} -h | ||||||
|  |     This help. | ||||||
|  |   ${SCRIPT} -i <av_file> -m <md5_file> | ||||||
|  |     Pass to the script the audio-visual file and the corresponding MD5 | ||||||
|  |     file to check. | ||||||
|  | Dependency: | ||||||
|  |   ffmpeg | ||||||
|  | About: | ||||||
|  |   Version: ${VERSION} | ||||||
|  |   Website: https://github.com/amiaopensource/ffmprovisr/blob/gh-pages/scripts/check_video_framemd5.sh | ||||||
|  | EOF | ||||||
|  |     exit 0 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | unset input_file | ||||||
|  | unset input_hash | ||||||
|  |  | ||||||
|  | while getopts ":hi:m:" opt; do | ||||||
|  |     case "${opt}" in | ||||||
|  |         h) _output_help ;; | ||||||
|  |         i) input_file=$OPTARG ;; | ||||||
|  |         m) input_hash=$OPTARG ;; | ||||||
|  |         :) echo -e "${RED}Error: option -${OPTARG} requires an argument${NC}" ; _output_prompt ;; | ||||||
|  |         *) echo -e "${RED}Error: bad option -${OPTARG}${NC}" ; _output_prompt ;; | ||||||
|  |     esac | ||||||
|  | done | ||||||
|  |  | ||||||
|  | [[ -z "${#}" || ! ${input_file} || ! ${input_hash} ]] && _output_prompt | ||||||
|  | echo -e "${BLUE}Please wait...${NC}" | ||||||
|  | unset md5_tmp | ||||||
|  | if [[ $OSTYPE = "cygwin" ]]; then | ||||||
|  |     md5_tmp="${USERPROFILE}/$(basename "${input_hash}").tmp" | ||||||
|  | else | ||||||
|  |     md5_tmp="${HOME}/$(basename "${input_hash}").tmp" | ||||||
|  | fi | ||||||
|  | ffmpeg -i "${input_file}" -loglevel 0 -f framemd5 -an "${md5_tmp}" | ||||||
|  | [[ ! -f "${md5_tmp}" ]] && { echo -e "${RED}Error: '${input_file}' is not a valid audio-visual file.${NC}" ; _output_prompt ; } | ||||||
|  | unset old_file | ||||||
|  | unset tmp_file | ||||||
|  | old_file=$(grep -v '^#' "${input_hash}") | ||||||
|  | tmp_file=$(grep -v '^#' "${md5_tmp}") | ||||||
|  | if [[ "${old_file}" = "${tmp_file}" ]]; then | ||||||
|  |     echo -e "${BLUE}'$(basename "${input_file}")' matches '$(basename "${input_hash}")'${NC}" | ||||||
|  |     rm "${md5_tmp}" | ||||||
|  | else | ||||||
|  |     echo -e "${RED}The following differences were detected between '$(basename "${input_file}")' and '$(basename "${input_hash}")':${NC}" | ||||||
|  |     diff "${input_hash}" "${md5_tmp}" | ||||||
|  |     rm "${md5_tmp}" | ||||||
|  | fi | ||||||
		Reference in New Issue
	
	Block a user