Re: [PD] opinions on the issue of concurrent implementations (was: getting sample rate of file loaded into an array)

2012-10-15 Thread Jonathan Wilkes
- Original Message -

> From: Roman Haefeli 
> To: "pd-list@iem.at" 
> Cc: 
> Sent: Friday, October 5, 2012 3:15 AM
> Subject: Re: [PD] opinions on the issue of concurrent implementations (was: 
> getting sample rate of file loaded into an array)
> 
> On Thu, 2012-10-04 at 13:16 -0700, Jonathan Wilkes wrote:
> [...]
>>  > Also, I wanted to know which is mature enough so that it's
>>  > worth to write bug reports to its author. This consumes quite some 
> time
>>  > and I think everyone who discovers that there are many solutions for 
> her
>>  > problem needs to invest some time to find out which works best.
>>  > Personally, I think this is lost time, because not only it needs twice
>>  > as much time to implement the same thing twice, every user needs to
>>  > figure out the small differences.
>>  > Well aware, that this (my) opinion is likely not applicable to others, 
> I
>>  > tend to think that patches are too much treated like holy cows whose
>>  > breaking should be avoided by any means. If it turns out, that my
>>  > patches use an inferior of concurrent implementations, I'd be 
> happy to
>>  > switch them to the new class, especially if it helps to keep the 
> future
>>  > clean.
>>   
>>  Advocate for the superior external, write crystal clear documentation
>>  for it, and write crystal clear documentation for the inferior one to 
> explain
>>  why to use the other one.  Then get the authors to accept your doc changes
>>  (or doc creation as the case may be).  That's the only way to ensure 
> that
>>  your lost time doesn't become other users' lost time.
> 
> You are right. I agree with you that this is probably the best (most
> pragmatic / most realistic) way to have an influence as a non-ext-dev on
> the issue.
> 
>>  I'll give you an example later when I update the arraysize help patch.
> 
> I'll happily check it, when it is ready.

Ok, I updated arraysize-help.pd in svn.

Still not sure how to get expr to point to the revised PDDP docs
instead of the old docs.

-Jonathan

> 
> Thanks for your thoughts.
> Roman
> 
> 
> 
> ___
> Pd-list@iem.at mailing list
> UNSUBSCRIBE and account-management -> 
> http://lists.puredata.info/listinfo/pd-list
> 

___
Pd-list@iem.at mailing list
UNSUBSCRIBE and account-management -> 
http://lists.puredata.info/listinfo/pd-list


Re: [PD] opinions on the issue of concurrent implementations (was: getting sample rate of file loaded into an array)

2012-10-06 Thread Patrice Colet

> De: "IOhannes m zmölnig" 
> On 10/04/2012 05:04 PM, Patrice Colet wrote:
> > 
> >  We should use C language only when we need it, in the example of
> >  [waveinfo] vs [soundfile_info], both aren't the good way for me,
> > we just need the [binfile] external for reading the header, and all
> > the other stuff can be done into a pd patch.
> > 
> 
> we don't need [binfile]!
> 

how do you read the header without binfile? 

> Pd is proven to be turing complete, so it should be easy enough to
> write
> an operating system entirely in Pd (that is: a patch) that will allow
> you to read/write soundfiles in any desired format.


pd is not even able to read extended precision, that's why pd can't tell about 
aiff samplerate.


___
Pd-list@iem.at mailing list
UNSUBSCRIBE and account-management -> 
http://lists.puredata.info/listinfo/pd-list


Re: [PD] opinions on the issue of concurrent implementations (was: getting sample rate of file loaded into an array)

2012-10-06 Thread Ed Kelly
>>  We should use C language only when we need it, in the example of [waveinfo] 
>>vs [soundfile_info], both aren't the good way for me,
>> we just need the [binfile] external for reading the header, and all the 
>> other stuff can be done into a pd patch.
>> 
>
>we don't need [binfile]!
>
>Pd is proven to be turing complete, so it should be easy enough to write
>an operating system entirely in Pd (that is: a patch) that will allow
>you to read/write soundfiles in any desired format.
>
>mgdasr
>IOhannes

True, but looking outside of the scope of audio for a second...
A student of mine did a project based on microwave background radiation 
measurements taken from radio telescopes, in order to deal with data that was 
truly random in some way (I'm skipping a debate about the randomness or 
otherwise in cosmological terms, the big bang etc.)
He accessed binary files to generate points. Admittedly this was in Processing, 
but the ability to deal with any binary data and decode it on an ad-hoc basis 
was essential for this project to work.

The point I am trying to make is that Pd should be able to read and write any 
file, with interpretation of the data implemented on an ad-hoc basis. In this 
way, mrpeach/binfile is incredibly useful. Obviously non-audio files will 
mostly generate noise if played back as audio, but Pd provides so many other 
ways in which data can be sonified, visualized etc...

Ed 


___
Pd-list@iem.at mailing list
UNSUBSCRIBE and account-management -> 
http://lists.puredata.info/listinfo/pd-list


Re: [PD] opinions on the issue of concurrent implementations (was: getting sample rate of file loaded into an array)

2012-10-05 Thread IOhannes m zmölnig
On 10/04/2012 05:04 PM, Patrice Colet wrote:
> 
>  We should use C language only when we need it, in the example of [waveinfo] 
> vs [soundfile_info], both aren't the good way for me,
> we just need the [binfile] external for reading the header, and all the other 
> stuff can be done into a pd patch.
> 

we don't need [binfile]!

Pd is proven to be turing complete, so it should be easy enough to write
an operating system entirely in Pd (that is: a patch) that will allow
you to read/write soundfiles in any desired format.

mgdasr
IOhannes

___
Pd-list@iem.at mailing list
UNSUBSCRIBE and account-management -> 
http://lists.puredata.info/listinfo/pd-list


Re: [PD] opinions on the issue of concurrent implementations (was: getting sample rate of file loaded into an array)

2012-10-05 Thread Roman Haefeli
On Thu, 2012-10-04 at 13:16 -0700, Jonathan Wilkes wrote:
[...]
> > Also, I wanted to know which is mature enough so that it's
> > worth to write bug reports to its author. This consumes quite some time
> > and I think everyone who discovers that there are many solutions for her
> > problem needs to invest some time to find out which works best.
> > Personally, I think this is lost time, because not only it needs twice
> > as much time to implement the same thing twice, every user needs to
> > figure out the small differences.
> > Well aware, that this (my) opinion is likely not applicable to others, I
> > tend to think that patches are too much treated like holy cows whose
> > breaking should be avoided by any means. If it turns out, that my
> > patches use an inferior of concurrent implementations, I'd be happy to
> > switch them to the new class, especially if it helps to keep the future
> > clean.
>  
> Advocate for the superior external, write crystal clear documentation
> for it, and write crystal clear documentation for the inferior one to explain
> why to use the other one.  Then get the authors to accept your doc changes
> (or doc creation as the case may be).  That's the only way to ensure that
> your lost time doesn't become other users' lost time.

You are right. I agree with you that this is probably the best (most
pragmatic / most realistic) way to have an influence as a non-ext-dev on
the issue.
 
> I'll give you an example later when I update the arraysize help patch.

I'll happily check it, when it is ready.

Thanks for your thoughts.
Roman



___
Pd-list@iem.at mailing list
UNSUBSCRIBE and account-management -> 
http://lists.puredata.info/listinfo/pd-list


Re: [PD] opinions on the issue of concurrent implementations (was: getting sample rate of file loaded into an array)

2012-10-04 Thread Jonathan Wilkes
- Original Message -
> From: Roman Haefeli 
> To: pd-list@iem.at
> Cc: 
> Sent: Thursday, October 4, 2012 10:44 AM
> Subject: [PD] opinions on the issue of concurrent implementations (was: 
> getting sample rate of file loaded into an array)
> 
> Hi all
> 
> The thread below makes me curious about what people think about the
> support of two or more several implementations of the similar
> functionality. 
> 
> There are a few such cases:
> * [ext13/wavinfo] vs. [iemlib/soundfile_info]
> * OSCx vs. mrpeach's osc library
> * arraysize vs.[expr size("array-name")]  (which could be turned 
> easily
> into an abstraction)
> 
> There are certainly more similar examples. Is that a good or a bad
> thing?
 
Inarguably there is a cost to the user of multiple developers solving
the same problem in a way that creates two or more externals that
do essentially the same thing.  There is a further cost to the users of
these externals having different interfaces, which is the vast majority
of the cases I've run into when revising help patches for externals.
There is another cost to both developers and users when all these
externals are packaged together (or separately) without regard for
the costs above or documentation that guides the user to choose
the least buggy/most featureful/expressive/etc. external in these
cases.  (And please note I'm talking about externals that are
essentially the same, _not_ externals that approach a broad problem
or domain from different perspective or design philosophy.)
 
There is a benefit to _developers_ of having a system where there is
essentially zero pressure in the community for them to work together
to at least create a common interface when adding functionality to
Pd through externals.  (The one exception is outputting messages 
received at the same logical time in right-to-left order which seems
to be obeyed by every external I've seen, even though it's possible
not to follow that design.)  Other than asking for svn commit permissions
there is really no barrier to entry.
 
There is probably also a cost to developers of not having something like
a "contributors guide" that specifies at least something about the
purpose of committing an external library to svn, not to mention the fact
that pre-Pd-extended libs very often seemed to have been simply a place
for some Pd users to remotely store a directory of utilities that they built
for their own personal use without much thought about designing them to
be generally useful or approachable by others.
 
> Do you rather find it annoying when you find two or more
> implementations for the same thing or do you consider it a question of
> choice: more is better?
 
If the two externals do _exactly_ the same thing but have a different name
the annoyance to the user is that they waste time asking on the list (or
figuring out on their own) that there is redundancy in Pd that provides no
benefit to them.
 
If one external is preferable to the other but this is not clearly documented,
then the annoyance is compounded, and possibly the user suffers from
using the less well-designed external before finding out about the better one.
 
If both externals have excellent documentation that clearly explains the 
benefits
of one over the other the annoyance is the time it takes the user to read the
documentation.
 
Also, if neither external is stable then the user also suffers from less quality
than they would have gotten if the developers of each had instead
focused their efforts into one solution with more eyes, more tests, and more
bug fixes.
 
> Is it possible at all to make generalizations
> about that? Is it the lesser of two evils to keep each implementation
> for the sake of backwards compatibility or is it preferable to focus on
> one single (best working) implementation and get rid of the rest (which
> breaks compatibility, of course)?
 
It is preferable to focus on one single best working implementation where
possible, but that doesn't imply that you need to get rid of redundant
implementations.  For me it means telling people to focus on the best
implementation and make them explain why an inferior implementation
that necessarily limits which versions of Pd the user's patch will run on
by default should drain any developer resources whatsoever.

> 
> My personal stance on the issue:
> I don't remember all cases, but in the case of [wavinfo] vs.
> [soundfile_info] I spent a lot of time figuring out which works for
> which files.
 
Exactly-- the developers' gain from not having to devote energy
to researching extant solutions and possibly working together is
your loss as a user.
 
> Also, I wanted to know which is mature enough so that it's
> worth to write bug reports to its author. This consumes quite some time
> and I think everyone who discovers that th

Re: [PD] opinions on the issue of concurrent implementations (was: getting sample rate of file loaded into an array)

2012-10-04 Thread Patrice Colet


> De: "Roman Haefeli" 
> 
> Hi all
> 
> The thread below makes me curious about what people think about the
> support of two or more several implementations of the similar
> functionality.
> 
> There are a few such cases:
> * [ext13/wavinfo] vs. [iemlib/soundfile_info]
> * OSCx vs. mrpeach's osc library
> * arraysize vs.[expr size("array-name")]  (which could be turned
> easily
> into an abstraction)
> 
> There are certainly more similar examples. Is that a good or a bad
> thing? Do you rather find it annoying when you find two or more
> implementations for the same thing or do you consider it a question
> of
> choice: more is better? Is it possible at all to make generalizations
> about that? Is it the lesser of two evils to keep each implementation
> for the sake of backwards compatibility or is it preferable to focus
> on
> one single (best working) implementation and get rid of the rest
> (which
> breaks compatibility, of course)?
> 
> My personal stance on the issue:
> I don't remember all cases, but in the case of [wavinfo] vs.
> [soundfile_info] I spent a lot of time figuring out which works for
> which files. Also, I wanted to know which is mature enough so that
> it's
> worth to write bug reports to its author. This consumes quite some
> time
> and I think everyone who discovers that there are many solutions for
> her
> problem needs to invest some time to find out which works best.
> Personally, I think this is lost time, because not only it needs
> twice
> as much time to implement the same thing twice, every user needs to
> figure out the small differences.
> Well aware, that this (my) opinion is likely not applicable to
> others, I
> tend to think that patches are too much treated like holy cows whose
> breaking should be avoided by any means. If it turns out, that my
> patches use an inferior of concurrent implementations, I'd be happy
> to
> switch them to the new class, especially if it helps to keep the
> future
> clean.
> 
Hi Roman,

 I think that it's better when we can modify the behavior of an object by 
modifying a pd patch.
When everything is enclosed into an external, somehow it's private, and then 
it's not really pd anymore.
 More people are able to debug a pd patch, anyone could fix the problem without 
compiling anything.

 We should use C language only when we need it, in the example of [waveinfo] vs 
[soundfile_info], both aren't the good way for me,
we just need the [binfile] external for reading the header, and all the other 
stuff can be done into a pd patch.

my one cent

___
Pd-list@iem.at mailing list
UNSUBSCRIBE and account-management -> 
http://lists.puredata.info/listinfo/pd-list


[PD] opinions on the issue of concurrent implementations (was: getting sample rate of file loaded into an array)

2012-10-04 Thread Roman Haefeli
Hi all

The thread below makes me curious about what people think about the
support of two or more several implementations of the similar
functionality. 

There are a few such cases:
* [ext13/wavinfo] vs. [iemlib/soundfile_info]
* OSCx vs. mrpeach's osc library
* arraysize vs.[expr size("array-name")]  (which could be turned easily
into an abstraction)

There are certainly more similar examples. Is that a good or a bad
thing? Do you rather find it annoying when you find two or more
implementations for the same thing or do you consider it a question of
choice: more is better? Is it possible at all to make generalizations
about that? Is it the lesser of two evils to keep each implementation
for the sake of backwards compatibility or is it preferable to focus on
one single (best working) implementation and get rid of the rest (which
breaks compatibility, of course)?

My personal stance on the issue:
I don't remember all cases, but in the case of [wavinfo] vs.
[soundfile_info] I spent a lot of time figuring out which works for
which files. Also, I wanted to know which is mature enough so that it's
worth to write bug reports to its author. This consumes quite some time
and I think everyone who discovers that there are many solutions for her
problem needs to invest some time to find out which works best.
Personally, I think this is lost time, because not only it needs twice
as much time to implement the same thing twice, every user needs to
figure out the small differences.
Well aware, that this (my) opinion is likely not applicable to others, I
tend to think that patches are too much treated like holy cows whose
breaking should be avoided by any means. If it turns out, that my
patches use an inferior of concurrent implementations, I'd be happy to
switch them to the new class, especially if it helps to keep the future
clean.

My two cents

Roman


On Thu, 2012-10-04 at 15:49 +0200, Roman Haefeli wrote:
> Hi Patrice and Rick
> 
> Unfortunately, there are several different types of wav files, also the
> header size is not always the same.
> 
> IIRC, [ext13/wavinfo] assumes a fixed size of the typical 44 byte header
> and probably because of other reasons as well does not recognize many
> real-world wav-files. Sometimes it gives totally strange numbers instead
> of reporting an error.
> 
> [iemlib/soundfile_info] seems to support a much wider range of wav-files
> around and also I reported once a bug and it got fixed. 
> 
> For reasons above I encourage you to use [iemlib/soundfile_info].
> 
> Roman
> 
> 
> 
> On Wed, 2012-10-03 at 14:09 -1000, Rick T wrote:
> > Thanks
> > 
> > On Wed, Oct 3, 2012 at 1:45 PM, Patrice Colet 
> > wrote:
> > [ext13/wavinfo]
> > 
> > or more complicated for the fun, with [mrpeach/binfile] and
> > https://ccrma.stanford.edu/courses/422/projects/WaveFormat/
> > 
> > it's attached ^^
> > 
> > Colet Patrice
> > 
> > - Mail original -
> > > De: "Rick T" 
> > > À: "PD List" 
> > > Envoyé: Jeudi 4 Octobre 2012 00:26:15
> > > Objet: [PD] getting sample rate of file loaded into an array
> > >
> > >
> > > Greetings All
> > >
> > > I load a wavefile into an array using openpanel but how can
> > I go
> > > about getting the sample rate of the wav file?
> > >
> > > I'm trying to load the sample rate data into an expr object
> > > Example: expr (sample rate) / f$1
> > >
> > > Aloh
> > > Rick
> > >
> > 
> > > ___
> > > Pd-list@iem.at mailing list
> > > UNSUBSCRIBE and account-management ->
> > > http://lists.puredata.info/listinfo/pd-list
> > >
> > 
> > ___
> > Pd-list@iem.at mailing list
> > UNSUBSCRIBE and account-management -> 
> > http://lists.puredata.info/listinfo/pd-list
> 
> 



___
Pd-list@iem.at mailing list
UNSUBSCRIBE and account-management -> 
http://lists.puredata.info/listinfo/pd-list