README.md: Updated notes.
cwFlowProc.cpp: Updated AudioFileOut to set output file bit format.
This commit is contained in:
parent
b8dea27343
commit
46191195b1
84
README.md
84
README.md
@ -52,6 +52,11 @@ optionally looks for duplicates as an error checking scheme.
|
|||||||
|
|
||||||
- change file names to match object names
|
- change file names to match object names
|
||||||
|
|
||||||
|
- Replace 24 bit read/write in cwAudioFile.cpp
|
||||||
|
|
||||||
|
- Remove Audio file operations that have been superceded by 'flow' framework.
|
||||||
|
|
||||||
|
|
||||||
- (DONE) change all NULL's to nullptr
|
- (DONE) change all NULL's to nullptr
|
||||||
|
|
||||||
- (DONE) implement kTcpFl in cwTcpSocket.cpp
|
- (DONE) implement kTcpFl in cwTcpSocket.cpp
|
||||||
@ -123,3 +128,82 @@ struct in_addr {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Flow Notes:
|
||||||
|
|
||||||
|
- Add a version of var_register() that both registers and returns the value of the variable.
|
||||||
|
|
||||||
|
- When a variable has a variant with a numberic channel should the 'all' channel variant be removed?
|
||||||
|
|
||||||
|
- Check for duplicate 'vid'-'chIdx' pairs in var_regster().
|
||||||
|
(The concatenation of 'vid' and 'chIdx' should be unique
|
||||||
|
|
||||||
|
|
||||||
|
- When a proc. goes into exec state there should be a guarantee that all registered variables
|
||||||
|
can be successfully read. No error checking should be required.
|
||||||
|
|
||||||
|
(How about source variables? these can never be written.)
|
||||||
|
|
||||||
|
- Make an example of a repeating input port. For example a mixer than takes
|
||||||
|
audio input from multiple processors.
|
||||||
|
|
||||||
|
- Make an example of a proc that has a generic port which allows any type, or a collection of
|
||||||
|
specific types, to pass through. For example a 'selector' (n inputs, 1 output) or a router
|
||||||
|
(1 signal to n outputs)
|
||||||
|
|
||||||
|
- Create a master cross-fader.
|
||||||
|
|
||||||
|
|
||||||
|
Flow Instance Creation:
|
||||||
|
-----------------------
|
||||||
|
|
||||||
|
1. Create all vars from the class description and initially set their
|
||||||
|
value to the default value given in the class. chIdx=kAnyChIdx.
|
||||||
|
|
||||||
|
Note that all vars must be included in the class description.
|
||||||
|
|
||||||
|
|
||||||
|
2. Apply the preset record from the class description according to the
|
||||||
|
label given in the instance definition.
|
||||||
|
|
||||||
|
If the variable valures are given as a scalar then the existing
|
||||||
|
variable is simply given a new value.
|
||||||
|
|
||||||
|
If the variable values are given as a list then new variables
|
||||||
|
records will be created with explicit channels based on the
|
||||||
|
index of the value in the list. This is referred
|
||||||
|
to as 'channelizing' the variable because the variable will then
|
||||||
|
be represented by multiple physical variable records - one for each channel.
|
||||||
|
This means that all variables will have their initial record, with the chIdx set to 'any',
|
||||||
|
and then they may also have further variable records will for each explicit
|
||||||
|
channel number. The complete list of channelized variable record
|
||||||
|
is kept, in channel order, using the 'ch_link' links with the base of the list
|
||||||
|
on the 'any' record.
|
||||||
|
|
||||||
|
3. Apply the variable values defined in the instance 'args' record.
|
||||||
|
This application is treated similarly to the 'class'
|
||||||
|
preset. If the variable value is presented in a list then
|
||||||
|
the value is assigned to a specific channel if the channel
|
||||||
|
already exists then the value is simply replaced, if the
|
||||||
|
channel does not exist then the variable is 'channelized'.
|
||||||
|
|
||||||
|
4. The varaibles listed in the 'in' list of the instance cfg.
|
||||||
|
are connected to their source variables.
|
||||||
|
|
||||||
|
5. The custom class constructor is run for the instance.
|
||||||
|
|
||||||
|
Within the custom class constructor the variables to be used by the
|
||||||
|
instance are 'registered' via var_register(). Registering
|
||||||
|
a variable allows the variable to be assigned a constant
|
||||||
|
id with which the instance can access the variable very efficiently.
|
||||||
|
|
||||||
|
If the channel associated with the registered variable does not
|
||||||
|
yet exist for the variable then a channelized variable is first created
|
||||||
|
before registering the variable.
|
||||||
|
|
||||||
|
6. The internal variable id map is created to implement fast
|
||||||
|
access to registered variables.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1797,6 +1797,7 @@ cw::rc_t cw::audiofile::writeFloat( handle_t h, unsigned frmCnt, unsigned ch
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 24:
|
case 24:
|
||||||
|
assert(0);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 32:
|
case 32:
|
||||||
|
@ -200,7 +200,8 @@ namespace cw
|
|||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
kInPId,
|
kInPId,
|
||||||
kFnamePId
|
kFnamePId,
|
||||||
|
kBitsPId
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
@ -215,12 +216,13 @@ namespace cw
|
|||||||
rc_t rc = kOkRC; //
|
rc_t rc = kOkRC; //
|
||||||
unsigned audioFileBits = 0; // set audio file sample format to 'float32'.
|
unsigned audioFileBits = 0; // set audio file sample format to 'float32'.
|
||||||
inst_t* inst = mem::allocZ<inst_t>(); //
|
inst_t* inst = mem::allocZ<inst_t>(); //
|
||||||
const abuf_t* src_abuf = nullptr;
|
const abuf_t* src_abuf = nullptr;
|
||||||
ctx->userPtr = inst;
|
ctx->userPtr = inst;
|
||||||
|
|
||||||
// Register variables and get their current value
|
// Register variables and get their current value
|
||||||
if((rc = var_register_and_get( ctx, kAnyChIdx,
|
if((rc = var_register_and_get( ctx, kAnyChIdx,
|
||||||
kFnamePId, "fname", inst->filename,
|
kFnamePId, "fname", inst->filename,
|
||||||
|
kBitsPId, "bits", audioFileBits,
|
||||||
kInPId, "in", src_abuf)) != kOkRC )
|
kInPId, "in", src_abuf)) != kOkRC )
|
||||||
{
|
{
|
||||||
goto errLabel;
|
goto errLabel;
|
||||||
@ -282,7 +284,7 @@ namespace cw
|
|||||||
// print a minutes counter
|
// print a minutes counter
|
||||||
inst->durSmpN += src_abuf->frameN;
|
inst->durSmpN += src_abuf->frameN;
|
||||||
if( inst->durSmpN % ((unsigned)src_abuf->srate*60) == 0 )
|
if( inst->durSmpN % ((unsigned)src_abuf->srate*60) == 0 )
|
||||||
printf("%5.1f %s\n", inst->durSmpN/(src_abuf->srate*60));
|
printf("%5.1f min\n", inst->durSmpN/(src_abuf->srate*60));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user