12

My company has a very broad range of products and there are a few that are not strategic to us so I wanted to open source them (so we can focus on what makes us unique and open source the products that every firm has).

Our industry(hedgefund) does not open source(we would be the first firm to try this) and the feedback I'm getting from my management team is either 1) we'll destroy the industry or 2) all competitive commercial firms will unite against us and we'll be wiped out either way. It's a big battle in my firm right now between the IT people who have seen the positive effects of sharing and the business people who think we'll be giving up everything (they prefer we sell parts we want to opensource, but in their defense this is standard when divesting something).

So what are your thoughts? Does open sourcing apply generally or is it only really applicable to software? Is it overall good for people in the industry and outside? I'm actually more interested in the negativeness effects(although positive are welcomed as well)

Update: Long story short, although code is involved this is not so much about code as it is more about the idea of open sourcing.

We are a mid sized quant hedge fund. We have some unique strategies but also have the standard long/short, arbitrage, global macro, etc.. funds.

We are keeping the unique funds we have but the other stuff that everyone else has we are considering open sourcing (We have put in years of work & millions of dollars into. Our funds is pretty popular and our performance is either in first or second quartile so I suspect there will be interest from firms in or thinking of getting into the industry but I don't know to what extent).

The goal is not to get a community to work for us, the goal is to let anyone who wants to tinker with it do so and create anything they want (it will not be part of our product line although I may unofficially allocate some our of staff's time to assist any community that grows). Although the code base is quite large, the value in this is the industry knowledge and approaches we have acquired (there are many books on artificial intelligence and quant trading but they are often years behind what's really going on as most firms forbid their staff from discussing what they are doing). Long story short, there maybe value here for people or not but I'm approaching open sourcing as a way to benefit the general public while we divest a product line up. But the flip side, is this is a core product to many other firms and they won't be happy(I think about linux/windows, wikipedia/britannica, google maps/commercial map firms, and so on). I'm fine with people disliking me but I'd rather it not be for unindented consequences and this question is to try to understand what those consequences generally are on industries that get core areas open sourced. For example, its hard to judge what part of the OS market grew because of Linux or was naturally growing on its own and so on. Technology has such fast grow and I'm struggling to understand how open sourced impacted it(and if it was positive or not. I.e. one of our large competitors has very large grants to top universities which obviously helps the schools, would open source limit the need for things like that?).

I understand this can seem very specific to me but I'm trying to understand general impact of open sourcing and software seemed like a good place to learn.

gnat
  • 21,442
  • 29
  • 112
  • 288
Lostsoul
  • 403
  • 2
  • 9
  • 2
    This question might fall into the categories of "freelancing and business concerns" or "software licensing." However, to make the question answerable, please provide additional background regarding the industry and what the product lines are that might be open sourced. It would help if you could list the OSS licenses / models being considered. And please note that "open source" != "out source"; they're completely different terms. At the moment, this question is too vague for anyone to be able to provide a meaningful answer. –  Jun 18 '12 at 17:20
  • 2
    Consider showing them what has happened with WiX when Microsoft open sourced it. –  Jun 18 '12 at 18:01
  • Thanks I'll look up that example. @GlenH7 I updated the question to hopefully shed some more light. – Lostsoul Jun 18 '12 at 18:06
  • Thanks for the update - the specificity provides enough context to generate some answers. I have some thoughts, and will put in an answer this afternoon. –  Jun 18 '12 at 18:14
  • Thanks Glen, look forward to it. @ThorbjørnRavnAndersen I looked up the wiki on WIX and I understand its been open sourced but I don't understand the impact to Microsoft after. – Lostsoul Jun 18 '12 at 19:25
  • Related/possible duplicate - http://programmers.stackexchange.com/questions/57674 – ChrisF Jun 18 '12 at 20:22
  • possible duplicate of [Isn't open source bad for developers themselves?](http://programmers.stackexchange.com/questions/139058/isnt-open-source-bad-for-developers-themselves) –  Jun 18 '12 at 20:41
  • 1
    This question is being [discussed on our meta discussion site](http://meta.programmers.stackexchange.com/q/3705/8). –  Jun 18 '12 at 21:20
  • @MarkTrapp Thanks for the notice. I'll work on cleaning it up, sorry for it sounding like a long rant. – Lostsoul Jun 18 '12 at 23:15
  • Depends on the licence you use. The GPL would permit other people to copy your source code, modify it slightly, and then sell it on at competition for cheaper than you are selling the original, or in the worst case just give it out free so nobody is profiting financially from your company's work. – Pharap Feb 09 '14 at 05:27

3 Answers3

15

There's a good possiblity that your firm could significantly change financial market making by releasing the source code. Having mulled through the idea, I have to agree that the pros outweigh the cons.

For what it's worth, I'm fairly familar with market structure. I interviewed with an exchange to join their IT staff. It wasn't a good fit and I didn't join them. But I think I understand the ramifications of what you're proposing.

Educational tool
There is a dearth of available programming talent in financial services. In my opinion, one of the biggest barriers to entry is (lack of) subject matter knowledge. There are few, if any, reference frameworks, and as you note, academia can't teach about information that isn't accessible.

I think there are a number of professors who could utilize the information and concepts instantiated by the source code. Theory is one thing; but having a concrete example is quite another.

Your firm's past results will be poured over by academics and competitors alike to determine what impact the flaws in the model(s) could have had on your returns. Disclaimer: all models have flaws, so that's not a critique by any means.

Driver for growth
There are a number of solid, successful open-source projects that have driven dramatic growth in the industry. Eclipse, Linux, and Apache are just three examples.

You described the projects you're releasing as being low-end, borderline commodity. Releasing them will absolutely push those areas into commodity land. That's not necessarily bad, as it enables many more people to participate. It also allows for untold innovation. It's impossible to predict what can happen when outside viewpoints are allowed to pick up the pieces and put them back together again.

Technology disrupter
On the negative side, this can be a serious technology disrupter like Linux, cell phones, digital media, etc. Whenever you open up a previously locked-down environment with a high barrier to entry, there is no telling what can or will occur. Some folks will end up losing jobs as the industry adapts to the game changers that could come out of this. Some would turn around and argue that this will introduce greater efficiencies and the ends justify the means.

Without being too dramatic, this is kind of like dropping a grenade in some of your competitors' laps. Effectively, you are forcing them to adapt to using more sophisticated models and to exit the soon-to-be completely commmodity environments they were working within.

Market Transparency
Given some of the recent SEC comments and public (mis)information about trading activity and dark pools, this may provide your company more attention than it was expecting. Some of it will be good. Some of it will be bad. Either way, it is something to consider.

Reference framework / Community
I would encourage you to allocate some staff time in order to document the projects and be available for follow-up questions. Dumping a large blob of otherwise opaque code into the ether will simply be an exercise in bit shuttling. If you provide a roadmap so people can understand the code base, then they'll have a means to dig in and start working with it.

Adoption rates and end-impact are difficult, if not impossible, to predict due to the number of variables involved. In almost all cases, though, the game changers started out small and grew incrementally. All the variants of Linux grew out of alpha geeks swapping stacks of 3.5" floppies or the occasionally revered burnt CD. Accessibility is a key aspect, and it's crucial to have folk available who understand the codebase.

To take things a step further, you could reach out to counterparts in other firms to see if they are considering a similar thing. Putting together a consortium, a.k.a. what is now the Apache Foundation, is one way of gaining critical mass. Another approach would be to generate tutorials, a la CodeAcademy, and run a minor public relations campaign in order to advertise it. These methods would help push the likely outcome into positive territory, but going into details would go beyond the scope of the original question.

To summarize the negatives:
- This can really disrupt the patterns that many have fallen into.
- Doing so will anger some of your competitors, who will malign you.
- You'll also pick up some negative press based upon misunderstandings of how the code and / or the market worked.

I would encourage you to use a GPLv3 license for this release precisely because of the viral nature of the license. Future modifications that are distributed must have their source released, which will in turn help grow any sort of community that may come from this.

To reframe this with your peers:
- This will make you look good in the eyes of the SEC (U.S. Securities and Exchange Commission) since you are trying to foster a level playing field.
- This code is a sunk cost that is no longer profitable for you. The long term benefits of improving available programming talent in the market are incalculable.
- This will encourage greater market efficiency, which is what we're all supposed to aspire to, since it gets us closer to correct valuation for equities.

  • 5
    A viral license such as GPL is not necessary to ensure that future modifications to the code must have their source released. If that's what you want, publish it under MPL instead. GPL's viral nature means that anything *else* that touches this code in any way must also have its source released. It's not about protecting the code in question, it's about pushing an anti-proprietary-code ideology. – Mason Wheeler Jun 18 '12 at 23:33
  • 1
    @MasonWheeler - you make a good point, and there is a fair amount to consider when picking a license. I recommended the viral component in order to ward off "theft" of the code base without a return back to the community. Normally, GPL is not my first choice. However, the non-technical factors involved made the viral component attractive. For the "greater good" that I believe the OP is striving for, the anti-proprietary-code ideology actually has some benefits in this case. The ideas that would be made Free would benefit from the protections of the GPL. –  Jun 19 '12 at 14:16
  • Thanks for the great answer, Glen. I haven't put much thought into license(our lawyers can handle that), but you make some great points. My personal view is I don't think we should retain any ownership and let people do what they want but I realize GPL may prevent people from making their own companies from it which I don't want to prevent(but I do like the idea of people sharing what they want). I may post a question once I learn more about the different trade offs. – Lostsoul Jun 19 '12 at 21:07
  • 2
    @Lostsoul If you want to enable others to make a company / LoB, then definitely do not go with the GPL. There are many other licenses better suited for that. MPL as Mason pointed out is one. BSD, Eclipse, IBM, Apache, and countless others also have licenses to consider in this case. –  Jun 19 '12 at 21:44
  • 1
    Thank you for your great answer and advice so far. You really have a excellent grasp of the question, industry and impacts. I don't think people outside of software understand the shift that open source caused. Thank you Glen for taking time to answer this. – Lostsoul Jun 19 '12 at 22:01
  • GPL v3 does not really encourage growth at all. People who don't want to release their source won't do it because the GPL says they should- they will instead simply *not make modifications*. Limiting the licence of the code of the user only serves to decrease the number of people willing to use the code. – DeadMG Jun 29 '12 at 09:16
  • @DeadMG - I struggle with that aspect of the GPL. And to be clear, I'm assuming you mean "to include / link" or "to modify the code" when you say "to use the code" and trigger the viral aspect. I'll admit that GPL isn't my first choice when I think about licensing something. But when I need code to be Free (ref: Stallman / GNU) then I think it's worth considering. There are a number of solid, GPL'd programs that have either directly or indirectly benefitted ALL programmers. Sometimes we have to tolerate limiting the linking / modification in order to provide greatest end user access. –  Jun 29 '12 at 11:34
  • 1
    Also, the marketing impact of having your company's name attached to THE standard software tool used by all serious players in your industry (if/when that happens) would be immense. – Matt Gibson Jun 29 '12 at 13:24
5

I think it's probably a bad idea to open-source anything that gives you a competitive edge. What would the advantage be to open-sourcing your code? You seem to say that the advantage would be:

so we can focus on what makes us unique and open source the products that every firm has.

It sounds like you're not planning to open-source your flagship product, but maybe some small utilities that ship with it, with the hope that the community will pick up the maintenance slack so your company can focus on the core product. That seems risky, if the community you hope for never materialises. Are these potential targets of open-sourcing potentially useful to other industries and users from other backgrounds? Do you really think it likely that random hackers will pick them up and improve them?


In response to your update: It sounds like the code you might open-source is very niche. How will you generate interest in it? How will you get people to tinker with it? If you just dump it on github or sourceforge and say "have fun!" who will find it, and how will they find it and why will they download it? The marketing side of this idea I think needs some work.

Maybe you should open-source some of it and market it to the students you want to hire later. Send some demo kits to professors so they can have their class use your software for their projects.

This will involve work though, someone will have to put together the kits for students, build the community website, monitor forums and answer questions, etc... Does your company have any interest in paying for all that? It could be a big benefit, but then again, maybe not...

FrustratedWithFormsDesigner
  • 46,105
  • 7
  • 126
  • 176
  • Thanks for the great answer. I updated the question to provide some more info about my firm but to some of your points I don't plan to return to this product so a community materializing or improvements to the product won't directly impact us(other than our staff learning from others forks so they can do their job better, and us being able to identify talent thats outside our industry. We only recuit from competitors and top schools in Chicago/NYC, this may allow us to find people outside those cities). – Lostsoul Jun 18 '12 at 18:13
  • @Lostsoul: I've updated in response to your updates. – FrustratedWithFormsDesigner Jun 18 '12 at 18:18
  • 1
    Another excellent answer, about whether it serves any purpose to open source the code. Very nice to see an outline of how to do it effectively e.g. demo kits to professors, website, forum support. That is not excessive for a company to fund, if they decide to choose this path. – Ellie Kesselman Jun 29 '12 at 08:01
2

Let me add my 2 cents on what @FrustratedWithFormsDesign said.

To get your company to do anything you have to do something to quantify the impact/benefit. No amount of talk or feeling or emotional outbursts (or frustration) will help in any way.

Use the 5-Why's technique to nail down the 'end-benefit' of actually open-sourcing the project. (You may need to ask more than 5 :) Now, you may land up with more than 1 end-goal, of course - since you can branch off on any answer and keep asking 'Why' (i.e. you may get a graph of causally linked goals and not just a linear tree).

See if you can quantify the goals as value gained to organization - if you think it's hard to measure I suggest reading "How to Measure Anything - Doug Hubbard" Now this should be used as your 'weapon of choice' for taking it to the higher management showing them the 'value' of open-sourcing. Unless the numbers are believable (along with risks factored in!) they won't even bother looking at it.

If they find something worthy of interest, they will spend some time to look into it further. Unless it aligns with their strategic interests and is value adding they WON'T look at it (or rather won't bother looking at it).

Hope this helps.

PS: You may also want to look up Business Model Canvas as an alternate means of communicating the same.

PhD
  • 2,531
  • 2
  • 18
  • 32
  • Up vote based on your words alone. I'm not criticizing your choice of linked references. That was a good thing to do, an extra effort that some will appreciate. But what you said, about making a convincing case, and quantifying it for upper management, is consistent with what I've observed to be effective. They never seem to care about frustration, outbursts, just sit through it without any discernible response (except maybe something negative that I don't realize). Addressing the issues you mentioned is necessary, regardless of any other context-specific considerations. – Ellie Kesselman Jun 29 '12 at 07:52