Pages:
Author

Topic: Tagebuch eines Bot Entwicklers (Read 16922 times)

member
Activity: 106
Merit: 10
January 20, 2015, 05:01:02 PM
Nächstes Beispiel.

Die Werte des Währungspaars fasse ich in einer Klasse zusammen:

Code:

/* base/counter currency pair class and its companion object */
object BCPair extends XMLTools {
  def apply(b: Double, c: Double) = new BCPair(b, c)
  def apply(bcp: BCPair) = new BCPair(bcp.b, bcp.c)
  def apply() = new BCPair()
  def apply(xml: Elem) = new BCPair( b = tDbl(xml \ "base"),
                                     c = tDbl(xml \ "counter"))
  val zero = BCPair(0, 0)
  val error = BCPair(-1, -1)
}

class BCPair (var b: Double = 0, var c: Double = 0) {

  /* data manipulation */
  def set(in: (Double, Double)) {b = in._1; c = in._2}
  def set(bcp: BCPair) {b = bcp.b; c = bcp.c}
  def set(bb: Double, cc: Double) {b = bb; c = cc}


  /* abs, rounding*/
  def abs = BCPair(scala.math.abs(b), scala.math.abs(c))
  def rnd(decs: DecSet) = BCPair( b = decs.rndBase(b),
                                  c = decs.rndCntr(c) )


  /* check conditions */
  def cndAND (f: Double => Boolean) = f(b) && f(c)
  def cndOR (f: Double => Boolean) = f(b) || f(c)


  /* standard operators */
  def + (that: BCPair) = new BCPair(this.b + that.b, this.c + that.c)
  def - (that: BCPair) = new BCPair(this.b - that.b, this.c - that.c)
  def * (d: Double) = new BCPair(this.b * d, this.c * d)
  def / (d: Double) = new BCPair(this.b / d, this.c / d)
  def isEqual (that: BCPair) = this.b == that.b && this.c == that.c

  /* calc the rate: i * r = c  <=> r = c / i */
  def calcRate = if (b != 0) scala.math.abs(c / b) else -1D


  /* delivers min/max values of both entries */
  def mergeMax(that: BCPair) = BCPair( b = tools.max(b, that.b),
                                       c = tools.max(c, that.c) )

  def mergeMinPos(that: BCPair) = {
    def oz(x: Double, y: Double) = (x > 0, y > 0) match {
      case (true, true) => tools.min(x, y)
      case (false, true) => y
      case (true, false) => x
      case (false, false) => 0D }
    BCPair(b = oz(b, that.b), c = oz(c, that.c)) }


  /* formatted output */
  def print = "base:" + b + " cntr:" + c

  def toStr( bcu: BCUnits, decB: Int, decC: Int) =
      fmtAmt(b, bcu.b, decB) + " | " + fmtAmt(c, bcu.c, decC)

  def toStr( bcu: BCUnits, fmtB: Double => String, fmtC: Double => String) =
      fmtAmt(b, bcu.b, fmtB) + " | " + fmtAmt(c, bcu.c, fmtC)

  def toStr(decs: Decimals, units: BCUnits): String =
      toStr(bcu = units, decB = decs.decBase, decC = decs.decCntr)

  def toStr(decs: DecSet, units: BCUnits): String =
      toStr(bcu = units, decB = decs.decBase, decC = decs.decCntr)


  /* XML output */
  def toXML = fXML(b.toString, c.toString)
  def toXML(decs: DecSet) = fXML(decs.fmtBase(b), decs.fmtCntr(c))
  private def fXML(sb: String, sc: String) =
              {sb}{sc}


  /* helper functions */
  private def cLen(s: String) = {if (s.indexOf("-") < 0) 1 else 0} + s.length

  private def fmtAmt(v: Double, unit: String, fmt: Double => String) = {
    val s = fmt(v)
    tools.pst( cLen(s), s) + " " + unit }

  private def fmtAmt(v: Double, unit: String, dec: Int) = {
    val s = tools.format(v, dec)
    tools.pst( cLen(s), s) + " " + unit }
}



Auch etwas länglich, aber ich kann jetzt ...

Code:

  // ... hiermit beispielsweise zwei Handelergebnisse aufsummieren.
  val a = BCPair(b = 1, c = 100)
  val b = BCPair(2, -30)
  val c = a + b // wäre hier BCPair(3, 70)

  // und mit der toStr-Methode ins Logfile schreiben
  log.trade("trade result -> " + c.toStr(decs.calc, ...)

  // oder testen, ob beide werte positiv sind
  if (c.cndAND (v => v > 0)) { ... }



Das erspart auch Arbeit bei der Deklaration von Klassen, beispielsweise einer Klasse, die die Handelsresultate aufnimmt:

Code:

/* the IFExTradeData class itself */
case class IFExTradeData ( dbid: Int,
                           typ: TTrdDir.TTrdDir,
                           bcu: BCUnits,
                           timestamp: Long,
                           tradeid: Long,
                           orderid: Long,
                           resultWOF: BCPair,
                           resultWF: BCPair,
                           fees: BCPair,
                           rateWOF: Double,
                           rateWF: Double)  extends IFExDataBase(dbid) {

  /* for error messages */
  override val errorClassName = "IFExTradeData"

  /* check on equality */
  def isEqual(that: IFExTradeData) = dbid == that.dbid &&
                                     typ == that.typ &&
                                     bcu == that.bcu &&
                                     timestamp == that.timestamp &&
                                     tradeid == that.tradeid &&
                                     orderid == that.orderid &&
                                     resultWOF.isEqual(that.resultWOF) &&
                                     resultWF.isEqual(that.resultWF) &&
                                     fees.isEqual(that.fees) &&
                                     rateWOF == that.rateWOF &&
                                     rateWF == that.rateWF

  /* type to string */
  def typStr = TTrdDir.toStr(typ)

  /* delivers a copy with setting of a changed database id */
  def copyWithDBID(id: Int) = copy(dbid = id)

  /* build log string */
  def toLog( indent: String, decs: DecSet) = {

    def strBCP(bcp: BCPair) =
      bcp.toStr( bcu, decs.fmtBase _, decs.fmtCntr _)

    List( "TRADEDATA",
          indent + "typ          :   " + typStr.toUpperCase,
          indent + "orderid      :   " + orderid,
          indent + "tradeid      :   " + tradeid,
          indent + "timestamp    :   " + tools.dateToString(timestamp),
          indent + "res w/o fee  :  " + strBCP(resultWOF),
          indent + "res w fee    :  " + strBCP(resultWF),
          indent + "fees         :  " + strBCP(fees),
          indent + "rate w/o fee : " + fmtValue(rateWOF, decs.fmtRate),
          indent + "rate w fee   : " + fmtValue(rateWF, decs.fmtRate)).mkString("\n") }




  /* creates a name/value map for database storing */
  override def dbValues(tableName: String, secID: Int) =
    Map( ("TableName", tableName),
         ("PrimaryKeyName", pkName),
         ("PrimaryKeyValue", dbid),
         ("secid", secID),
         ("typ", typStr),
         ("base", bcu.b),
         ("cntr", bcu.c),
         ("timestamp", timestamp),
         ("tradeid", tradeid),
         ("orderid", orderid),
         ("ratewof", rateWOF),
         ("ratewf", rateWF)) ++
         mapBCP("resultwof", resultWOF) ++
         mapBCP("resultwf", resultWF) ++
         mapBCP("fees", fees)

  /* stores to database, only if not exists */
  override def store(db: Database, table: String, secID: Int) =

    /* checks if dataset already exists */
    db.selectFromDB( table, "where tradeid=" + tradeid, "") match {

      /* dataset retrieved --> no action */
      case rs: ResultSet if rs.next() => rs.close()

      /* no dataset found --> store */
      case rs: ResultSet => super.store(db, table, secID); rs.close()
      case _ => super.store(db, table, secID) }


}



Wieder alles etwas länglich, aber sehr nützlich für die einheitliche Behandlung der Daten von verschiedenen Exchanges.
member
Activity: 106
Merit: 10
January 20, 2015, 04:42:10 PM
@serpens66

Also grundsätzlich mache ich alles so allgemein verwendbar wie möglich.


Beispiel Nachkommastellen. Ich unterscheide drei Fälle: Anzeige, Rechnungen und Handeln. Beispielsweise Nxt auf Bter:  Wird mit drei Nachkommastellen gehandelt, aber mit acht Nachkommastellen berechnet und gespeichert.


In der Konfigurationsdatei gibts einen Abschnitt, der die Nachkommastellen definiert, jeweis für base (NXT), counter (BTC) und die rate, zu der das gehandelt wird.

Quote

        
        

            
                8
                8
                8
            


            
                8
                8
                7
            


            
                3
                8
                7
            


        




Dann gibt es eine Klasse, die drei Instanzen eines Dezimalstellen-Sets aufnimmt. Das wird beim Start geladen und erzeugt.


Code:

case class Decimals ( calc: DecSet,
                      show: DecSet,
                      trade: DecSet )





Code:
case class DecSet ( decRate: Int,
                    decBase: Int,
                    decCntr: Int,
                    fmtHRtA: String => String,
                    fmtHRtB: String => String) {

  import tradebot.div.tools._

  /* rounding */
  def rndRate(v: Double) = roundDouble(v, decRate)
  def rndBase(v: Double) = roundDouble(v, decBase)
  def rndCntr(v: Double) = roundDouble(v, decCntr)

  /* formatting */
  def fmtRate(v: Double) = format(v, decRate)
  def fmtBase(v: Double) = format(v, decBase)
  def fmtCntr(v: Double) = format(v, decCntr)


  /* highlight the four relevant decimals */
  def fmtHRate(v: Double) = { ... }
}




Jetzt kann ich anderen Klassen zu verschiedenen Zwecken Instanzen dieser DecSet- Klasse übergeben und muß mich nicht mehr um Runden, Formatieren etc. kümmern.

Beispiel

Code:
case class SDBasicTrade ( trdDirection: TTrdDir.TTrdDir,
                          amount: Double,
                          rate: Double) {

  def toStr(decs: DecSet, units: BCUnits) =
      List( TTrdDir.toStr(trdDirection).toUpperCase, decs.fmtBase(amount),
              units.b, "@", decs.fmtRate(rate)).mkString(" ")
}



Jetzt kann ich sehr schnell und einheitlich eine Ausgabe auf die Konsole erzeugen:


Code:

   val trade = SDBasicTrade ( trdDirection = tdBuy,
                                           amount = 1,
                                           rate = 0.01 )

   println("executing trade -> " + trade.toStr(decs.trade, ... )
   logic.executeTrade(trade)




So, die ganzen Vorarbeiten sind natürlich etwas länglich, aber wenn sie gemacht sind, kann ich alle Dezimalstellen einheitlich runden und formatieren. Und muß für ein anderes Handelpaar an einer anderen Exchange nur ein paar Zahlen in einer Konfigurationsdatei ändern.
legendary
Activity: 2968
Merit: 1133
January 20, 2015, 02:40:06 PM
Besteht daran Interesse, ich könnte hier hoffentlich aufschlußreichen SourceCode reinstellen?
Ich schreibe meinen Bot ja in Python und lerne diese Sprache (als meine erste richtige Programmiersprache) auch gerade.
Meine bisherigen Konstrukte laufen größtenteils linear und mit wenig Verzweigungen, weshalb wenn ich was neues zufügen will,  ich alles neuschreiben müsste. Natürlich wird aber auch in Python normalerweise so programmiert, dass man z.b problemlos eine neue Börse aufnehmen kann, ohne alles komplett neu zu schreiben/zu ändern.
Daher hätte ich schon Interesse daran, wie sowas aussehen kann, wenn auch in einer anderen Sprache, aber ich denke es wird schon verständlich genug sein Smiley
member
Activity: 106
Merit: 10
January 20, 2015, 10:03:11 AM
Da gibt es gerade neu ein Buch mit dem Titel "Sie wissen alles" zu kaufen. Darin gibt es Hinweise wie Profis aus Banken ihre Bots entwickeln.

Wie machen die das denn?
member
Activity: 106
Merit: 10
January 20, 2015, 10:02:14 AM
Implementierung eines AntiCycle-Bots sein. Und die allererste sich stellende Frage ist nicht-technischer Natur, nämlich welches Handelspaar:
Bei solchen Fragen gehe ich immer nach den Ausschlußprinzip vor. Zuerst alle Alternativen auflisten und dann die schlechten Alternativen streichen.

Meine Ausschlußkriterien sind:

[...]


Danke.

Ich habe mich für STR|BTC auf Poloniex entschieden. Die von dir genannten Punkte sind eingermaßen gewährleistet - darüber hinaus habe ich mich dafür entschieden, weil ->

* ich STR für vergleichsweise langlebig halte
* das Verhältnis schwankt natürlich, aber vermute, daß es nicht zu stark schwanken wird.
* ich einen Grund habe, meine ExchangeInterface-Bibliothek zu erweitern.


Bis jetzt habe ich ->

* die groben, aber schon lauffähigen Klassenstrukturen, die ich in die
Ausführungsroutine der "Bot-Oberklasse" einhängen kann, gemacht. Auch die Datenbanktabellen, Konfigurationsdateien usw.

* ExchangeInterface abgeleitet und teilweise implementiert. Das ist inzwischen einfach nur langweilig.

* Die Kernroutinen dieser AntiCycle-Logik - nämlich Berechnung der Relation und der daraus folgenden Handelsgrößen, unter Berücksichtigung der bid bzw. ask-Seite - vollständig, genau, fehlerbehandelnd und allgemein verwendbar implementiert.

* Erste Strukturen der die AntiCycle-Logik einbindenen Handelslogik. Abläufe etc.

* Das mit anderem bestehenden Code harmonisiert, Code-Wiederholungen in "Traits" (so heißt das bei Scala) oder Elter-Klassen ausgelagert etc.

Wenn ich mir das so durchlese, gar nicht so schlecht.


Anyway - ich mache das schon etwas länger und einige meiner Konstrukte (Klassen) zu Behandlung der typischen Aufgaben eines Handelsbots haben sich für mich als sehr nützlich erwiesen. Beispielsweise eine konfigurierbare Klassen für Fee-Berechungen, Behandlung von Währungswertepaaren, Dezimalstellen etc.

Besteht daran Interesse, ich könnte hier hoffentlich aufschlußreichen SourceCode reinstellen?


sr. member
Activity: 388
Merit: 250
January 20, 2015, 07:00:55 AM
Implementierung eines AntiCycle-Bots sein. Und die allererste sich stellende Frage ist nicht-technischer Natur, nämlich welches Handelspaar:
Bei solchen Fragen gehe ich immer nach den Ausschlußprinzip vor. Zuerst alle Alternativen auflisten und dann die schlechten Alternativen streichen.

Meine Ausschlußkriterien sind:

Geringes Handelsvolumen Ein Antizyklus Bot stellt keine zusätzlichen offenen Orders in den Markt, er nimmt nur vorhandene Orders an. d.h. wenn ein weiterer Bot in den Markt kommt, wird das Handelsvolumen nicht oder nur minimalst steigen. Alle Märkte, deren Volumen zumindest nicht 10.000 (zehntausend) mal höher als Deine Investition sind, kannst Du streichen.

Volumen der offenen Orders Ein Antizyklus Bot braucht, bei kleineren Gewichtungskorrekturen pro Prozent der Preisänderung ein halbes Prozent von Deiner Investition an Ordervolumen im Markt. Ich würde 10% Preisänderung als Grenze sehen, mit der der Bot noch funktioniren sollte, alse 5% Deiner Investition sollten jederzeit im Besten Bid/Ask Paar des Marktes verfügbar sein.

Bid/Ask Spread Da ein Antizyklus Bot immer nur vorhandene Orders im Markt nimmt, hat er bei 2 Korrekturen in die entgegengesetzte Richtung den Abstand zwischen Bid und Ask zu überwinden. Dieses Kriterium hängt stark mit dem vorigen zusammen, meist haben Märkte mit gut gefüllten Orderbüchern auch einen geringen Spread.

Handelspreis im Verhältnis zur kleinsten Handelseinheit Oft sind die Kommastellen im Preis auf weniger als 8 Stellen beschränkt. Die kleinstmögliche Preisänderung sollte den Wert eines Coins im Handelspaar um weniger als 1% verändern.

Spesen Die Spesen nicht vergessen! Ein Antizyklus Bot kann durch die Spesen rasch unprofitabel werden, macht der Bot 2 Korrekturen in die entgegengesetzte Richtung, fallen die Spesen doppelt an.

minimale Ordergröße Bei vielen Märkten muß die Order eine bestimmte Größe haben. Ein Antizyklus Bot stellt eher kleinere Orders in den Markt, sodaß das bei kleinen Investitionen bereits ein Problem werden kann. Falls der Bot Fehlgewichtungen von 1% korrigieren soll, darf die minimale Ordergröße nicht kleiner sein als 0,5% der Investition.

Wieviel möchtest Du vom Bot verwalten lassen? Auf welcher Exchange? Es macht einen großen Unterschied, ob Du mit 10 EUR oder 10000 EUR startest, die Kriterien filtern in Abhängigkeit von der Investition ganz andere Märkte heraus.
member
Activity: 106
Merit: 10
January 14, 2015, 12:17:38 PM
Hallo Smiley ...

Habe gestern nach langer Zeit mal wieder ins Forum geguckt und diesen Thread über antizyklisches Handeln entdeckt. Sehr interessant - habe ich dort auch zum Ausdruck gebracht.

Ich mache auch crypto currency trading bots, und das auch schon etwas länger. Eher alleine und mit sehr geringem Austausch, vor allem, weil ich die Bots, die versuchen, Prognosen zu treffen, nicht so interessant finde. Eine einfache mathematische Grundlage wie die Antizyklische Strategie mag ich mehr.

Habe allerdings auch einen Bot gemacht, der den Ichimoku-Indikator als Trendsignal benutzt und die Parameter des Indikators mittels genetischer Algorithmen ständig optimiert. Erfolg war durchaus da, habe aber nach VPS-Provider-Wechsel vorübergehend das Interesse daran verloren. Der neue Provider ist sehr billig (7,5$ py, und irgendwie schlecht), und hat nicht genug Rechenleistung für die Optimierung.

Anyway - als Programmiersprache benutze ich Scala. Ist eher wenig verbreitet, aber ich mag es und es ist sehr effektiv. Banken etc. stellen zunehmend auf Scala um. Die Twitter-Message-Loop ist in Scala programmiert, netflix benutzt es auch.

Es war nett zu lesen, wie sich andere durch die Standard-Probleme durchgekämpft (wie Nachkommastellen auf bter etc.) haben. Ich habe als Resultat dieses Lernprozesses inzwischen drei bis vier Abstrahierungsschichten zwischen der konkreten Exchange-Klasse und der Logik Smiley ...


Mein nächstes Projekt wird die Implementierung eines AntiCycle-Bots sein. Und die allererste sich stellende Frage ist nicht-technischer Natur, nämlich welches Handelspaar: https://bitcointalksearch.org/topic/m.10152920


Was meint ihr Smiley ... ?


newbie
Activity: 11
Merit: 0
January 11, 2015, 12:47:32 PM
Da gibt es gerade neu ein Buch mit dem Titel "Sie wissen alles" zu kaufen. Darin gibt es Hinweise wie Profis aus Banken ihre Bots entwickeln.
hero member
Activity: 700
Merit: 500
January 08, 2015, 05:10:56 PM
... 300€ sind schon eine gaaaaanze Menge Geld.... kein Deswegen würde mir die günstigst-mögliche Variante schon zusagen, die aber dennoch nicht zuviel zusätzlichen Aufwand benötigt.
Schön wäre vermutlich so eine Preisklasse von maximal 100€, wobei ich den Aufwand einen Rasperry zu programmieren für mich mal mit einem Wert von 70€ beziffere Cheesy (weürde also 70€ mehr zahlen, wenn ich keinen Einrichtungsaufwand des Gerätes habe).
Du brauchst ja nicht gleich morgen einkaufen gehen. Einige Zeit musst Du den Bot ja ohnehin überwacht laufen lassen, auf Anhieb funktioniert so ein großes Projekt nicht problemlos. Ich würde sagen, die Hardwareentscheidung hat noch so lange Zeit, bis der Bot längere Zeit ohne Probleme funktioniert hat.

Investiere die 70 EUR besser in Kapital für Deinen Bot, die Installationsanleitungen findest Du ja gratis im Internet.


Gibts denn nichts mit Windows oderso in der Preisklasse 50-100€?
Nein. Ich würde Dir auch NICHT raten, einen gebrauchten Computer in dieser Preisklasse zu kaufen. Da bleibt nur ein Raspberry als Alternative. Ich hatte vor 15 Jahren auch aus der Windows Welt kommend, mit Linux zu tun, das war zwar eine Umstellung, aber nach einer Zeit gewöhnt man sich an die Möglichkeiten die eine Linux Shell so bietet. Du muss ja nicht ein Raspberry Guru werden, im Internet gibt es Installationsanleitungen, wenn es einmal eingerichtet ist, brauchst Du nur Dein Python Programm auf den Raspberry kopieren (entwickeln kannst Du ja bequem am PC) und dann starten/stoppen. Den Bot zu schreiben ist die größere Hürde.

+1 nimmst mir die Worte aus dem Mund Wink wobei ich erst vor einem Jahr durch den PI mit Linux angefangen hatte...solange konnte ich mehr wehren Wink
sr. member
Activity: 388
Merit: 250
January 08, 2015, 03:23:28 PM
... 300€ sind schon eine gaaaaanze Menge Geld.... kein Deswegen würde mir die günstigst-mögliche Variante schon zusagen, die aber dennoch nicht zuviel zusätzlichen Aufwand benötigt.
Schön wäre vermutlich so eine Preisklasse von maximal 100€, wobei ich den Aufwand einen Rasperry zu programmieren für mich mal mit einem Wert von 70€ beziffere Cheesy (weürde also 70€ mehr zahlen, wenn ich keinen Einrichtungsaufwand des Gerätes habe).
Du brauchst ja nicht gleich morgen einkaufen gehen. Einige Zeit musst Du den Bot ja ohnehin überwacht laufen lassen, auf Anhieb funktioniert so ein großes Projekt nicht problemlos. Ich würde sagen, die Hardwareentscheidung hat noch so lange Zeit, bis der Bot längere Zeit ohne Probleme funktioniert hat.

Investiere die 70 EUR besser in Kapital für Deinen Bot, die Installationsanleitungen findest Du ja gratis im Internet.


Gibts denn nichts mit Windows oderso in der Preisklasse 50-100€?
Nein. Ich würde Dir auch NICHT raten, einen gebrauchten Computer in dieser Preisklasse zu kaufen. Da bleibt nur ein Raspberry als Alternative. Ich hatte vor 15 Jahren auch aus der Windows Welt kommend, mit Linux zu tun, das war zwar eine Umstellung, aber nach einer Zeit gewöhnt man sich an die Möglichkeiten die eine Linux Shell so bietet. Du muss ja nicht ein Raspberry Guru werden, im Internet gibt es Installationsanleitungen, wenn es einmal eingerichtet ist, brauchst Du nur Dein Python Programm auf den Raspberry kopieren (entwickeln kannst Du ja bequem am PC) und dann starten/stoppen. Den Bot zu schreiben ist die größere Hürde.
legendary
Activity: 2955
Merit: 1050
January 08, 2015, 02:09:24 PM

Kann man so einen Raspberry denn irgendwo fertig einrichten lassen, sodass ich mich wirklich garnicht mit Linus auskennen muss? Programmieren lernen reicht mir fürs Erste, möchte mich wirklich nicht auch noch mit Linus beschäftigen müssen =/
Gibts denn nichts mit Windows oderso in der Preisklasse 50-100€?
hier
http://www.raspberrypi.org/downloads/
hast du fertige Linux images zum download und z.B. Raspbian
(Debian Wheezy) ist gut und einfach zum Einstieg.

edit:
hier noch ein Vergleich
http://www.raspberry-pi-geek.de/Magazin/2013/05/Distributionen-fuer-den-Raspberry-Pi-im-Ueberblick
legendary
Activity: 2968
Merit: 1133
January 08, 2015, 01:12:54 PM
Danke für die antworten Smiley

@kalkulatorix:
ich hab ja schon mehrere API Anfragen und diese dauern grob überschlagen je 1 Sekunde.  Ganz genau habe ich es noch nicht nachvollzogen, was wie lange braucht.  Verzögerungen sind nur 0,5 sekunden eingebaut. Wie gesagt beschäftige ich mich jetzt mit Threads (für mich als programmieranfänger noch nicht ganz so leicht, aber wird schon Cheesy) und dann mal schauen, wieviel Zeit ich einsparen kann Smiley

Auch wenn ich schon ein paar Gewinne durch Bitcoins machen konnte, bin ich dennoch nur Student und 300€ sind schon eine gaaaaanze Menge Geld. Hatte bis vor kurzem auch noch einen alten Röhrenfernseher, kein Smartphone, ein kaputtes Bett, einen sehr alten Laptop usw. Neu kaufe ich die Dinge erst, wenns wirklich garnicht mehr anders geht Cheesy  oder wenn ich so wie jetzt gebrauchte Dinge von Verwandten geschenkt bekomme, die aber dennoch um ein vielfaches Neuer sind, als meine Dinge Cheesy
Deswegen würde mir die günstigst-mögliche Variante schon zusagen, die aber dennoch nicht zuviel zusätzlichen Aufwand benötigt.
Schön wäre vermutlich so eine Preisklasse von maximal 100€, wobei ich den Aufwand einen Rasperry zu programmieren für mich mal mit einem Wert von 70€ beziffere Cheesy (weürde also 70€ mehr zahlen, wenn ich keinen Einrichtungsaufwand des Gerätes habe).
Bezüglich Android hätte es ja sein können, dass es da bereits irgendwelche Apps (eine art sehll) gibt, mit denen man Skripte ausführen kann. dann müsste ich nichts direkt mit android machen.

@Darkwinde:
Oh man Cheesy Altcoin-exchanges scheinen eine ziemlich dämliche API zu haben ^^  
Kann man so einen Raspberry denn irgendwo fertig einrichten lassen, sodass ich mich wirklich garnicht mit Linux auskennen muss? Programmieren lernen reicht mir fürs Erste, möchte mich wirklich nicht auch noch mit Linux beschäftigen müssen =/
Gibts denn nichts mit Windows oderso in der Preisklasse 50-100€?
hero member
Activity: 700
Merit: 500
January 08, 2015, 10:29:01 AM
Sorry muss mal wieder ranten...
Ich bekomme schon wieder Plack. Hab durch Zufall gesehen, dass der PHP Parser auf einmal meinte in Zeile XY von API Bittrex würde es Offset 1 nicht geben...
Schaue es mir an, kratz mich am Kopf. Erstelle Testdaten....alles OK...kann doch nicht sein...

So nach 2 Stunden jetzt die Lösung... (sorry fürs Schreien) DIE SCHE.... API SCHNITTSTELLE VON BITTREX GIBT ALS ORDERTYPE "Limit_Buy" ZURÜCK UND WENN SIE GERADE LUST HAT FÜR DICH GLEICHE ORDER AUCH MAL NUR "Buy"...
AHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH wie soll man mit so nem Mist arbeiten


So hab mich jetzt ausgekotzt Wink

-----------------

Warum nimmst kein Raspberry PI kostet doch nur 30€ und verbraucht nur paar Watt...
sr. member
Activity: 388
Merit: 250
January 08, 2015, 09:20:07 AM
Python ist übrigens multithread-fähig
Das ist eine guten Nachricht, da ergeben sich schon einmal mehrere Möglichkeiten.

Aktuell braucht es vom erkennen bis zur ausführung 5 sekunden, was leider oft zu lange ist
Das dauert genau 5 Sekunden? Für eine Analyse des Problem solltest Du erst herausfinden, wie lange jeder einzelner Schritt der Verarbeitung dauert. Ohne mit Kraken Erfahrungen zu haben, erscheinen mir die 5 Sekunden lange für 1*Fund,1*Open_Orders und 3*Market. OOps, das sind ja genau 5, hast Du vielleicht die Verzögerungen eingebaut und mitgerechnet, damit Du nicht über das API Limit kommst?

Mir kam der Gedanke, ob es nicht auch möglich ist, so ein Skript auf einem Tablet zu betreiben? Würde mir halt ungerne ein neues gerät anschaffen wollen.
Das kann ich jetzt nicht nachvollziehen. Selbst bei mir in Österreich kostet so ein Mini PC unter 300 EUR, das sind doch Peanuts im Vergleich dazu, was er im Laufe der Zeit bringen wird. Unterschätze nicht die Schwierigkeiten, die auf Dich zukommen, wenn Du unter Android programmieren willst.

Weiters sollte ein Bot ja 24/7 laufen, das ist mit einem Tablett nur schwer zu erreichen, wenn man es so verwendet, wofür es gedacht ist.
legendary
Activity: 2968
Merit: 1133
January 08, 2015, 07:20:38 AM
nochmal danke für eure antworten kalkulatorix und darkwinde Smiley 
Python ist übrigens multithread-fähig, weshalb ich das noch dementsprechend umschreiben werde Smiley Aktuell braucht es vom erkennen bis zur ausführung 5 sekunden, was leider oft zu lange ist =/

Mir kam der Gedanke, ob es nicht auch möglich ist, so ein Skript auf einem Tablet zu betreiben? Würde mir halt ungerne ein neues gerät anschaffen wollen. Ich kenne mich nicht mit den nötigen Vorraussetzungen und den Möglichkeiten eines mittelmäßigen Android Tablets aus... aber eigentlich sollte das doch möglich sein?  WLAN kann man sogar im Ruhezustand aktiviert lassen, also sollte man es doch auch hinbekommen, dass im Ruhezustand der Bot arbeitet?  Denkt ihr sowas geht?
hero member
Activity: 700
Merit: 500
January 05, 2015, 04:35:52 PM
Aktuell BTer, Bittrex, Poloniex und Cryptsy.
Weitere können aber bei Bedarf noch implementiert werden hatte aberbisher kein Bedarf.
Bin da flexibel was eure Wünsche anbelangt.

viele der neuen cryptos werden auf

   AllCrypt
   Coins-E
   AllCoin
   Coin-Swap
   SwissCEX
   AskCoin
   UseCryptos.com
   .
   .
   .


gehandelt und gerade am Anfang ist meist hohe Volatilität...

hier
https://de.cryptonator.com/exchange
hat man einen schönen Überblick  Smiley

Nur weil ein Exchange einen neuen Coin ASAP integriert, heißt es ja nicht, dass andere das auch tun. Bei Dreiecks Arbitrage auf einem Exchange geht das, keine Frage, aber nicht bei meiner Methode über zwei Exchanges...

Trotzdem guter Hinweis zu der Seite (merke ich mir) und auch welche Börsen potenziell interessant sein könnten für meine nächsten APIs
Danke dir
legendary
Activity: 2955
Merit: 1050
January 05, 2015, 01:26:58 PM
Aktuell BTer, Bittrex, Poloniex und Cryptsy.
Weitere können aber bei Bedarf noch implementiert werden hatte aberbisher kein Bedarf.
Bin da flexibel was eure Wünsche anbelangt.

viele der neuen cryptos werden auf

   AllCrypt
   Coins-E
   AllCoin
   Coin-Swap
   SwissCEX
   AskCoin
   UseCryptos.com
   .
   .
   .


gehandelt und gerade am Anfang ist meist hohe Volatilität...

hier
https://de.cryptonator.com/exchange
hat man einen schönen Überblick  Smiley
hero member
Activity: 700
Merit: 500
January 05, 2015, 09:13:39 AM
Ach noch zur Bot-betreibung:
Welche Möglichkeiten habe ich da denn? Also entweder den Pc den ganzen Tag laufen lassen. Sich ein kleines stromsparendes Gerät wie einen Rasperry kaufen (gibts noch andere leichter einstellbare alternativen? weiß nicht ob ich mich mit Linux rumschlagen möchte). Oder einen Server mieten? Ein Server mieten würde vermutlich heißen, dass ich mein Skript irgendwo hochlade und der Dienstleister dieses dann für mich ausführt, richtig? Was kostet sowas im schnitt, ist es günstiger oder teurer als die anschaffung eine rasperry (oder für welchen Zeitraum lohnt sich was davon). Und sind meine Daten auf dem Server sicher? Schließlich steht im Skript mein API Key und bei manchen Exchanges sogar Username und passwort. Nicht dass die das nutzen können und mich bestehlen ^^

Ist am Ende des Tages eine Sache, was dir am Besten gefällt. Das aagt dir jemand der erst auf seine alten Tage vor einem Jahr mit Linux angefangen hat: Linux rumschlagen musst du dich nicht viel, sind paar Kommandozeilen Parameter und das ding rennt dann bis zum Ende aller Tage. Updates sind auch einfacher als bei Windows. Will meine beiden Rasps nimmer missen. Aber auch jeder andere Mini PC tut es auch und Windows ist ja auch nicht so das Schlimmste Wink schau dich doch einfach mal um und lass dann danach entscheiden was dir ein sicheres Gefühl gibt und was nicht dein Geldbeutel zu sehr schröpft.
sr. member
Activity: 388
Merit: 250
January 05, 2015, 06:12:54 AM
Quote
Du bekommst ja nur eine OrderID, wenn eine Order angelegt wird, also die Order nicht sofort vollständig durchgeführt werden konnte. Mit dem Order Cancel Versuch erkennst Du nur jene Order als korrekt durchgeführt, die beim Absenden der Order nicht sofort vollständig durchgeführt wurden, aber innerhalb von 10 Sekunden komplett durch waren. Vor allem bei Teilweise ausgeführten Orders kannst Du Dir mit dieser Logik Probleme einfangen, Da Du nicht weißt, ab eine gecancelts Order teilweise ausgeführt wurde. Ich würde da eher so vorgehen, wie Du weiter unten schreibst.
Habe das gerade mal bei Kraken getestet. Da bekomme ich auch eine OrderID, wenn die Order sofort ausgeführt wird. Bin aber gerade auch dabei, jetzt das mit den OpenOrders einzubauen. Ich frage also alle open orders ab, schaue ob meine Id dort noch vorhanden ist. Wenn ja, dann rufe ich das executed volume ab um zu erfahren, ob sie teilweise erfüllt ist.
Ich bin mir noch unsicher, wie ich verfahren sollte, wenn tatsähclich eine Order nicht/nur teilweise erfüllt wird... Entweder kehre ich dann trotzdem zur Ausganswährung zurück mit eventuellen Verlusten. Zurzeit stelle ich alle KAuf/Verkaufsorders gleichzeitig rein.  Man könnte es auch so machen, dass man erst die erste ORder reinstellt und diese kontrolliert, ob sie sofort erfüllt wurde. Wenn ja, dann werden die restlichen Orders reingestellt. Wenn nein, dann wird der Vorgang abgebrochen. Das minimiert also die Chance, dass ich in die Situation komme, dass etwas unerfüllt ist.  Dafür habe ich aber auch eine kleine Zeitverzögerung von ca. 1 sekunde zur Kontrolle ob die erste Order erfüllt ist...
Wie hast du das gelöst? Ich glaube Darkwinde z.b. hatte geschrieben, dass er die orders dann einfach drin lässt mit der begründung "das wird schon iwann angenommen", oder?  Wenn ich manuell trade und mir sowas passiert, dann analysiere ich erstmal die Lage und schätze ab, ob die Order noch erfüllt werden könnte und ziehe evtl nach oder schließe sie mit Verlust. Ich kann das ganz gut einschätzen. Aber der Bot kann das nicht. Deswegen müsste man da eine einzige konsequente Vorgehensweise programmieren. Und da wäre mir eine Schließung der Position schon lieber, als evlt in noch größere Verluste zu geraten.

Ich kümmere mich gar nicht darum, ob die Order erfüllt ist oder nicht. Wenn ich eine Arbitrage gefunden habe, stelle ich alle Order gleichzeitig in den Markt, schreibe das Ergebnis ins Logfile und gut ist es. Dann warte ich 10 Sekunden und frage dannach die "availiable Funds" ab, und der Bot lauert auf weitere Arbitragen. Dadurch blieben so schöne Orders stehen wie verkaufe BTC um 620 oder verkaufe LTC um 7.9. Das reduziert mir die "availiable Funds" zwar, aber bis jetzt at sich das Aussitzen von offenen Orders immer noch ausgezahlt. Da würde ich eventuell das Volumen der Arbitragen beschränken, damit der Bot nicht handlungsunfähig wegen zu wenig Funds wird.

Ich habe leider noch kein API für Kraken, sorry für die Fehlinformation wegen der OrderID bei erfüllten Orders.

Naja, die Limits der Exchanges sind schon ziemlich eng. Soweit ich das bei Kraken verstanden habe, habe ich für die meisten Abfragen 10 Calls pro 5 sekunden.  Wenn ich nun also bei 3 currencies immer wieder ziwschendurch, in derselben Funktion, die Daten abfrage, ist das schon nach 3 Abfragen voll ^^ und da sind dann andere Abfragen wie openorders oderso noch garnicht mit drin. Also ich hab da eig nicht besonders viel Spielraum.

Ich würde davon ausgehen, daß der Bot das Einzige ist, was Orders in den Markt stellt. Wenn Du manuell eingreifen willst, stell den Bot ab, oder bau eine "Pause" ein, sodaß Du den Bot anhalten kannst, wenn Du manuell in die Exchange eingreifen willst.

Dann brauchst Du nicht so viele zusätzlichen Abfragen. Wenn eine Order erfüllt wird, erhöhen sich die "availiable Funds" in jedem Fall. Verringern tun sich die "avaliable Funds" nur, wenn Du Orders in den Markt stellst, die nicht erfüllt werden. Somit brauchst Du die Funds nur beim Start, Neustart nach Pause, nach Trades und sonst nur alle 5 Minuten. (je mehr Reserven Du hast, desto länger bleibt Dein Bot handlungsfähig und Du kannst das Intervall weiter erhöhen.)  Wenn Du Dich nicht darum kümmerst, ob die Orders erfüllt werden, oder nicht, kannst Du die Open Orders Abfrage ganz weglassen, oder das Handling der offenen Orders nur alle 15 Minuten machen, höchstens so oft, wie Du die Funds abfragst.


Ach noch zur Bot-betreibung:
Welche Möglichkeiten habe ich da denn? Also entweder den Pc den ganzen Tag laufen lassen. Sich ein kleines stromsparendes Gerät wie einen Rasperry kaufen (gibts noch andere leichter einstellbare alternativen? weiß nicht ob ich mich mit Linux rumschlagen möchte). Oder einen Server mieten? Ein Server mieten würde vermutlich heißen, dass ich mein Skript irgendwo hochlade und der Dienstleister dieses dann für mich ausführt, richtig? Was kostet sowas im schnitt, ist es günstiger oder teurer als die anschaffung eine rasperry (oder für welchen Zeitraum lohnt sich was davon). Und sind meine Daten auf dem Server sicher? Schließlich steht im Skript mein API Key und bei manchen Exchanges sogar Username und passwort. Nicht dass die das nutzen können und mich bestehlen ^^
Ich habe 3 lüfterlose Stromsparcomputer, die haben eine Quadcore Laptop CPU verbaut, und sind als Bot-Hardware vollkommen überdiemensioniert. CPU Last nur 1-3% durch den Bot. Stromverbrauch maximal 65 Watt, Kaufpreis aber 1400 EUR. Ich denke, Du würdest da auch mit irdenteinem billigeren USFF (Ultra Small Form Faktor) Computer auskommen, die Gefahr bei einem kleinen Gehäuse ist aber, dass die Lüfter angehen, das nervt auf Dauer gewaltig. Ein Ding mit Atom Prozessor reicht locker aus. Zum Raspberry kann ich nicht viel sagen, bin Windows gewöhnt und möchte in meinem Alter nicht mehr so viel Neues erlernen.


Edit: Unbedingt eine Professional Windows Version für den Bot - Computer verwenden. Nur die Professional Versionen habe einen Remote Desktop inkludiert, sodaß Du den Bot - Compter von Deinem Haupt - Computer fernsteuern kannst. Da brauchst Du, abgesehen von der Erstinstallation keinen Bildhschirm und Tasatur mehr am Bot - Computer, der kann dann irgendwo stehen, wo er keinen Hitzestau bekommt.
legendary
Activity: 2968
Merit: 1133
January 05, 2015, 02:57:19 AM
@kalkulatorix:

Nun will und kann ich ja aber nicht ständig weitere API Abfragen reinstellen, um zu kontrollieren, ob eine Order angenommen wurde oder nicht.
Wieso? Sende soviele API Anfragen an die Exchange wie es für Dich nötig und von der Exchange her zulässig ist.
Naja, die Limits der Exchanges sind schon ziemlich eng. Soweit ich das bei Kraken verstanden habe, habe ich für die meisten Abfragen 10 Calls pro 5 sekunden.  Wenn ich nun also bei 3 currencies immer wieder ziwschendurch, in derselben Funktion, die Daten abfrage, ist das schon nach 3 Abfragen voll ^^ und da sind dann andere Abfragen wie openorders oderso noch garnicht mit drin. Also ich hab da eig nicht besonders viel Spielraum.




@Darkwinde:

Quote
> Wenn du die Orderbücher abfragst, bekommst auch zum einen immer das Volumen und die Tiefe mit. Du brauchst also keine zweite Abfrage nur deine erste etwas Aufbohren. Ich schreibe solche Infos immer in ein Array.
jop, meinte kalkulatorix ja auch schon. werde ich so machen.

Quote
> Wenn du Sicherheit gewinnen willst, berechne erst alle Notwendigen Informationen, ob der Trade gut wäre und prüfe zum Schluss nochmal ob die selben Marktbedingungen noch existent sind. Das mache ich auch so, danach feuer frei
hmhm.. ist nur immer schwierig zu erfassen. Weil ich all die Operationen und Abfragen ja theoretisch zurselben Zeit, also in derselben Funktion mache. Das heißt gäbe es keine Verzögerung durch Hardware, Software Inetleitung usw., dann wäre es auch alles zurselben Zeit. Aber wie gesagt, da muss ich mal ein Tool suchen, um zu sehen, wie lange mein Skript tatsächlich braucht und ob es sinnvoll ist, zu anfang und nach den Berechnungen die Werte abzufragen. (nicht sinnvoll wäre es z.b wenn dazwischen dann nur 0,0x sekunden liegen würden)

Quote
> Logdateien werden dein Bester Freund, sieh schon jetzt eine Logging Klasse vor die du immer bemühst um Daten wegzuschreiben. Gerade das Debugging wird enorm einfacher wenn du einfach mal wichtige Codestellen im Log ausgeben lassen kannst.
Nur zu meinem Verständnis, bin ja noch recht neu was das Programmieren angeht: Eine Logdatei ist doch einfach nur eine Datei, in der ich aufschreiben lasse, was so alles passiert ist. Das heißt wenn keine Profite gefunden werden und auch keine Fehler auftreten steht da für den entsprechenden Zeitraum (kann man ja nach Tag gliedern, oder?) nichts drin. Und sonst steht da nur das drin, was ich vorher festlege, also z.b bei Fehlern dann die fehlermeldungen und bei ausgeführten Trades dann evlt noch die Gewinne und sonstige hilfreiche Dinge. Letzlich ist es also dasselbe wie bisher die Ausgabe in meiner Shell (ich lasse Ereignisse und Fehler immer per "print" ausgeben), mit dem unterschied, dass es abgespeichert wird und zu jeder Zeit daher wieder nachvollziehbar ist.
"Debugging" heißt das auffinden und beheben von Fehlern, richtig?
Wieso soll ich eine Logging Klasse schreiben? Wie würde diese aussehen bzw. wozu wäre sie da? Vermutlich würde ich einfach im Botskript selbst nach jedem Ereignisauslösendem Teil sowas schreiben wie log("es wurde x zu y€/BTC gekauft"), angenommen "log()" sorgt dafür, dass der Text in die logdatei geschrieben wird.
Und wie kann ich mir über die Logdatei wichtige Codestellen ausgeben lassen? Undwozu brauche ich das? Den Code kann ich mir doch direkt im Skript ansehen. Oder meinst du bei Fehlermeldungen, dass dort die Codestelle mit dem Fehler genannt wird?

Quote
> Du solltest nicht auf Exception bei der Erfüllung von Orders prüfen, das geht spätestens bei Partiell Erfüllten Orders schief. oftmals bieten die Exchanges ein API Call an, der dir sagt ob eien Order bereits geschlossen wurde und was der Grund dafür war. Cancel <-> Erfüllt
Gleiches gilt auch für teilweise Erfüllte Orders. Ich meien, dass es Bittrexx ist, die das sogar ganz wüst machen. Da hast du zum Einen Orders die in der API als offen stehen aber gleichzeitig in der History auftauchen ^^ da muss man dann beides verbinden...
jop, ist wie oben erwähnt in Arbeit Smiley


Quote
> Du musst dir überlegen, wie und wann du mit Partiell Erfüllten Orders umgehst. Da gibt es diverse Einflüsse und musst dir ein Konzept überlegen. Nimm dir zeit dafür.
hast du dazu denn noch Ratschläge?


Quote
> Zeitmessung in Python kann sicher wie in PHP gehen. Nimm aktuelle Zeit vor der Methode und nach der Methode, abziehen und tada haste die Durchlaufgeschwindigkeit ^^
ja das klingt sinnvoll, werde ich so ausprobieren Smiley





Ach noch zur Bot-betreibung:
Welche Möglichkeiten habe ich da denn? Also entweder den Pc den ganzen Tag laufen lassen. Sich ein kleines stromsparendes Gerät wie einen Rasperry kaufen (gibts noch andere leichter einstellbare alternativen? weiß nicht ob ich mich mit Linux rumschlagen möchte). Oder einen Server mieten? Ein Server mieten würde vermutlich heißen, dass ich mein Skript irgendwo hochlade und der Dienstleister dieses dann für mich ausführt, richtig? Was kostet sowas im schnitt, ist es günstiger oder teurer als die anschaffung eine rasperry (oder für welchen Zeitraum lohnt sich was davon). Und sind meine Daten auf dem Server sicher? Schließlich steht im Skript mein API Key und bei manchen Exchanges sogar Username und passwort. Nicht dass die das nutzen können und mich bestehlen ^^
Pages:
Jump to: