2017-09-23 22:39:19 -04:00
|
|
|
//
|
|
|
|
// TrackSerialiser.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 23/09/2017.
|
2018-05-13 15:19:52 -04:00
|
|
|
// Copyright 2017 Thomas Harte. All rights reserved.
|
2017-09-23 22:39:19 -04:00
|
|
|
//
|
|
|
|
|
2024-01-16 23:34:46 -05:00
|
|
|
#pragma once
|
2017-09-23 22:39:19 -04:00
|
|
|
|
|
|
|
#include "../DPLL/DigitalPhaseLockedLoop.hpp"
|
2017-09-26 22:01:32 -04:00
|
|
|
#include "PCMSegment.hpp"
|
|
|
|
#include "Track.hpp"
|
2017-09-23 22:39:19 -04:00
|
|
|
|
2023-05-10 16:02:18 -05:00
|
|
|
namespace Storage::Disk {
|
2017-09-23 22:39:19 -04:00
|
|
|
|
|
|
|
/*!
|
|
|
|
Instantiates a PLL with a target bit length of @c length_of_a_bit and provides a complete
|
|
|
|
serialisation of @c track, starting from the index hole.
|
|
|
|
|
|
|
|
This feature is offered for the benefit of various parts of the code that need to make
|
|
|
|
sense of a track **other than emulation**, as it renders a one-off image of the track,
|
|
|
|
which can be inaccurate. However there are many occasions where a single rendering is
|
2018-05-13 15:34:31 -04:00
|
|
|
desireable, e.g. file formats that apply that constraint, or static analysis prior to
|
2017-09-23 22:39:19 -04:00
|
|
|
emulation launch, which works with broad strokes.
|
|
|
|
|
|
|
|
@param track The track to serialise.
|
|
|
|
@param length_of_a_bit The expected length of a single bit, as a proportion of the
|
|
|
|
track length.
|
|
|
|
*/
|
2018-05-18 23:03:28 -04:00
|
|
|
PCMSegment track_serialisation(const Track &track, Time length_of_a_bit);
|
2017-09-23 22:39:19 -04:00
|
|
|
|
|
|
|
}
|