Tuple0 would need special serialization and comparator logic. If that is given, I see no reason not to support it.
There is BTW, the request to create a dedicated "flink-tuple" project, that only contains the tuple classes. Any opinions on that? On Mon, Aug 3, 2015 at 12:45 AM, Matthias J. Sax < mj...@informatik.hu-berlin.de> wrote: > Thanks for the explanation! > > As I mentioned before, Tuple0 might also be helpful for streaming. And I > guess I will need it for Storm compatibility layer, too. (I need to > double check, but Storm supports zero-attribute-tuples, too). > > With regard to the information I collected during the discussion, I vote > for keeping Tuple0 in Flink core, and fix the serialization problem. > Should we have another JIRA for this? Or should I extend the existing > JIRA? (https://issues.apache.org/jira/browse/FLINK-2457) > > -Matthias > > > On 08/03/2015 12:22 AM, Chesnay Schepler wrote: > > First of all, it was a really good idea to start a discussion about this. > > > > So the general idea behind Tuple0 was this: > > > > The Python API maps python tuples to flink tuples. Python can have empty > > tuples, so i thought "well duh, let's make a Tuple0 class!". What i did > > not wanna do is create some non-Tuple object to represent empty tuples, > > I'd rather have them treated the same, because it's less work and > > creates simpler code. > > > > When transferring the plan to java, certain parameters for operations > > are tuples, which can be empty aswell. > > This is where the Tuple0 class is really useful, because these empty > > tuples go through the same logic as other tuples. > > This is also why i want to keep the class, at least in the python > > project, for now. > > > > For the actual program execution, I need a new solution. Funny story, > > while writing this reply i noticed that the Python API can't handle > > Tuple0 at runtime aswell. ha...ha... -.- > > > > Guess I now know what I'm working on next. > > > > On 02.08.2015 21:24, Matthias J. Sax wrote: > >> Can you elaborate how and why Python used Tuple0? If it cannot be > >> serialized similar to regular Tuples, what is the usage in Python? Right > >> now it seems, as there is no special serialization code for Tuple0. > >> > >> I just want to understand the topic in detail. > >> > >> -Matthias > >> > >> > >> On 08/01/2015 03:38 PM, Stephan Ewen wrote: > >>> I think a Tuple0 cannot be implemented like the current tuples, at > least > >>> with respect to runtime serialization. > >>> > >>> The system makes the assumption that it makes progress in consuming > >>> bytes > >>> when deserializing values. If a Tuple= never consumes data from the > byte > >>> stream, this assumption is broken. It would need at least one marker > >>> byte. > >>> Then it effectively is a Tuple1<Byte> disgusing itself as a tuple0. > >>> > >>> > >>> > >>> On Sat, Aug 1, 2015 at 1:38 PM, Matthias J. Sax < > >>> mj...@informatik.hu-berlin.de> wrote: > >>> > >>>> I just double checked. Scala does not have type Tuple0. IMHO, it would > >>>> be best to remove Tuple0 for consistency. Having Tuple types is for > >>>> consistency reason with Scala in the first place, right? Please give > >>>> feedback. > >>>> > >>>> -Matthias > >>>> > >>>> > >>>> On 08/01/2015 01:04 PM, Matthias J. Sax wrote: > >>>>> I see. > >>>>> > >>>>> I think that it might be useful to have Tuple0, because in rare > cases, > >>>>> you only want to "notify" a downstream operators (taking about > >>>>> streaming) that something happened but there is no actual data to be > >>>>> processed. Furthermore, if Flink cannot deal with Tuple0 it should be > >>>>> removed completely for consistency IMHO. > >>>>> > >>>>> I will open a JIRA for it. > >>>>> > >>>>> -Matthias > >>>>> > >>>>> On 07/31/2015 10:44 PM, Chesnay Schepler wrote: > >>>>>> also, I'm not sure if I ever sent a Tuple0 through a program, it > >>>>>> could > >>>>>> be that the system freaks out. > >>>>>> > >>>>>> On 31.07.2015 22:40, Chesnay Schepler wrote: > >>>>>>> there's no specific reason. it was added fairly recently by me > >>>>>>> (mid of > >>>>>>> april), and you're most likely the second person to use it. > >>>>>>> > >>>>>>> i didn't integrate into all our tuple related stuff because, well, > i > >>>>>>> never thought anyone would actually need it, so i saved myself the > >>>>>>> trouble. > >>>>>>> > >>>>>>>> Hi, > >>>>>>>> > >>>>>>>> is there any specific reason, why Tuple.getTupleClass(int arity) > >>>>>>>> does > >>>>>>>> not support arity zero? There is a class Tuple0, but it cannot be > >>>>>>>> generator by Tuple.getTupleClass(...). Is it a missing feature (I > >>>> would > >>>>>>>> like to have it). > >>>>>>>> > >>>>>>>> -Matthias > >>>>>>>> > >>>>>>> > >>>> > > > >