Trading-Stocks.de

Normale Version: Open Source Tools und Daten
Du siehst gerade eine vereinfachte Darstellung unserer Inhalte. Normale Ansicht mit richtiger Formatierung.
Seiten: 1 2 3 4 5
(13.01.2023, 14:03)Lancelot schrieb: [ -> ]Die Diskussion hatte ich erst vor kurzem mit jemanden aus der frühen Schachprogrammierwelt. Eventuell ist das alles gar nicht so toll, was wir Menschen machen. Also unsere Intelligenzleistung ist vielleicht nicht so überragend ...

Warum so "negativ" gestimmt? Natürlich ist die Intelligenzleistung überragend, denn "wir" sind die Schöpfer solcher Innovationen.

Ich muss ja auch zugeben, dass ich zu der Fraktion "AI, LOL, hat man schon in den 60er gehypted und wir warten immer noch sehr, sehr, sehr lange drauf", aber ich finde das Thema hochinteressant.

Spinnt man das "zu Ende", wird es eines Tages möglich sein, Welten, in welchen wir leben zu simulieren und dann gibt es ganz andere Möglichkeiten ... werde ich aber nicht mehr erleben, es sei denn, wir befinden uns bereits in einer Simulation, geschaffen von unserem Schöpfer Wink
(03.01.2023, 10:44)Lancelot schrieb: [ -> ]Python war hier am Board schon mehrfach im Gespräch. 

Hier die wichtigsten packages für den Umgang mit Daten:

pandas: Alles was man mit xls machen kann...und mehr. Wenn man sich eingearbeitet hat, ist es recht intuitiv:
https://pandas.pydata.org/

polars: wenn die Daten größer werden, mann aber noch immer auf einem einzelnen Rechner arbeiten will. PyArrow als Columns. Geschrieben in Rust:
https://www.pola.rs/

scipy: wichtige library für Nummerik, Statistik und signal processing (FFT!)
https://scipy.org/

scikit learn: supervised und unsupervised learning (PCA...wichtig für Factor Analysis). Immernoch der Gold Standard im MAchine Learning:
https://scikit-learn.org/stable/

klassische statistische Modellierung. Hypothesetests und SARIMAX Zeitreihenprognose. Hat auch einen wrapper um das berühmte "forecast" R-packagde von Hyndman.  
https://www.statsmodels.org/stable/index.html 

Data is King. Immer noch. Aber auf der algorithmischen Seite kommt Gradient Boosting free-lunch erstaunlich nahe. Es ist erstaunlich wie gut Anfänger mit den Default-Einstellungen werden können. Auch die Hyperparameter Optimierung lässt sich mit Copy& Paste aus der Dokumentation gut hinbekommen.
Hier die 3 Platzhirsche:
https://xgboost.readthedocs.io/en/stable/ (NVIDIA)
https://catboost.ai/ (Yandex)
https://lightgbm.readthedocs.io/en/v3.3.2/ (Microsoft)

Darts: ich bin noch immer nicht zufrieden, aber es geht in die richtige Richtung. Endlich mal ein brauchbares time series package:
https://unit8co.github.io/darts/ 

der quantopian stack:
zipline: backtesting engine
https://github.com/quantopian/zipline
Pyfolio; Portfolio Analyse:
https://github.com/quantopian/pyfolio

danke für die ausgesuchten links für py Anwendungen
bin in (meist) jupyter notebook am Strategie schreiben und
bin am Info Austausch interessiert (Rad nicht neu erfinden)

EMA, MACD, RSI, Aaron ?
(06.03.2023, 13:03)Noni-Binder schrieb: [ -> ]danke für die ausgesuchten links für py Anwendungen
bin in (meist) jupyter notebook am Strategie schreiben und
bin am Info Austausch interessiert (Rad nicht neu erfinden)

EMA, MACD, RSI, Aaron ?

Pandas:[attachment=12694]
Code:
import pandas as pd
import pandas_datareader.data as web

df= web.DataReader('SPY', 'stooq')
df["mid_price"] = 0.5 * (df.Close + df.Open) 
df["ewma_1"] = df["mid_price"].ewm(span=12, adjust=False).mean()
df["ewma_2"] = df["mid_price"].ewm(span=26, adjust=False).mean()
df["macd"] = (df.ewma_1 - df.ewma_2).ewm(span=10, adjust=False).mean()
  
df[["mid_price","ewma_1","ewma_2","macd"]].plot(figsize = (15,7),grid= True, secondary_y=True)   
danke für's script als feedback

als grafische Erweiterung ein Tageschart des DAX von eben.
Die vertikalen Linien rot/grün zeigen die möglichen Schaltunkte für Aaron Indikator
Verfeinerung der Schaltunkte mit EMA, Max/Min od. crossover RSI und MACD.
Hier der Tageschart, der das Prinzip aufzeigt.

das macd script steht zum Test an;
wenige script Zeilen sind erstrebenswert, wie dieses scriptlet :-)

teste mit EOD Daten
ALV screenshot mit RSI,MACD
in Arbeit sind:  Aaron und buy/sell markers
Perioden Auschnitt eines  Testlaufs:
Aaron  buy/sell markern - scheint ok
Eintrag in Kurs plot ??   Wonder
...ist hier angedacht die, scriptlets rein zu stellen ?
(09.03.2023, 11:23)Noni-Binder schrieb: [ -> ]...ist hier angedacht die, scriptlets rein zu stellen ?

würde zumindest helfen und Zeit sparen  Tup
(09.03.2023, 12:31)TomJoe schrieb: [ -> ]würde zumindest helfen und Zeit sparen  Tup

Code:
#pip install yfinance
#pip install mplfinance
import yfinance as yf
import mplfinance as mpf
import talib as ta
import numpy as np
import pandas as pd
import math
from mplfinance import _styles
#_styles.available_styles()
# styles = ['binance','blueskies','brasil','charles','checkers','classic','default','ibd',
# 'kenan','mike','sas','starsandstripes','yahoo']
#------------------------------------------------
path = 'C:/....your path to file.csv/'
symbol = 'ALV.DE'    # bei yahoo für DAX xxx.DE verwendet
#------------------------------------------------
data= yf.download(symbol, period='9mo')   # max, 1y,3mo,5min
data.to_csv(path+symbol + '_1y.csv')
#------------------------------------------------
# check data to plot
#mpf.plot(data, type='candle', figsize=(20,5),mav=(5,20), volume=True)
#------------------------------------------------
# # Calculate MACD values using the pandas_ta library
df['ema9'] = df['Close'].ewm(span=9, adjust=False, min_periods=12).mean()
df['ema12'] = df['Close'].ewm(span=12, adjust=False, min_periods=12).mean()
df['ema26'] = df['Close'].ewm(span=26, adjust=False, min_periods=12).mean()

# Subtract the 26-day EMA from the 12-Day EMA to get the MACD signal line
df['macd_line'] = df['ema12'] - df['ema26']
df['macd_signal'] = df['macd_line'].ewm(span=9, adjust=False, min_periods=9).mean()
#------------------------------------------------
# check mpf plot
mpf.plot(df, type='candle', volume=True, addplot=macd_plot)
#------------------------------------------------
#  macd plot
import mplfinance as mpf
import talib as ta

from matplotlib import style
import matplotlib.pyplot as plt
plt.style.use('classic')

def MACD(df, window_slow, window_fast, window_signal):
    macd = pd.DataFrame()
    macd['ema_slow'] = df['Close'].ewm(span=window_slow).mean()
    macd['ema_fast'] = df['Close'].ewm(span=window_fast).mean()
    macd['macd'] = macd['ema_slow'] - macd['ema_fast']
    macd['signal'] = macd['macd'].ewm(span=window_signal).mean()
    macd['diff'] = macd['macd'] - macd['signal']
    macd['bar_positive'] = macd['diff'].map(lambda x: x if x > 0 else 0)
    macd['bar_negative'] = macd['diff'].map(lambda x: x if x < 0 else 0)
    return macd

macd = MACD(df, 12, 26, 9)

macd_plot = [
mpf.make_addplot((macd['macd']), color='#606060', panel=2, ylabel='MACD', secondary_y=False),
mpf.make_addplot((macd['signal']), color='#1f77b4', panel=2, secondary_y=False),
mpf.make_addplot((macd['bar_positive']), type='bar', color='#4dc790', panel=2),
mpf.make_addplot((macd['bar_negative']), type='bar', color='#fd6b6c', panel=2),]
mpf.plot(df, type='candle', volume=True, addplot=macd_plot)
#-------------------------------------------

# macd
data["macd"], data["macd_signal"], data["macd_hist"] = ta.MACD(data['Close'])
# plot macd
macd_plot = mpf.make_addplot(data["macd"], panel=1, color='fuchsia', title="MACD")
colors = ['g' if v >= 0 else 'r' for v in data["macd_hist"]]
macd_hist_plot = mpf.make_addplot(data["macd_hist"], type='bar', panel=1, color=colors) # color='dimgray'
macd_signal_plot = mpf.make_addplot(data["macd_signal"], panel=1, color='b')
#----------------------------------------------
def detect_macd_signals(data):
    """Use MACD cross-over to decide buy/sell
    Args:
      data: panda DataFrame with OHLC with MACD data
   
    Return:
      buy_signals, sell_signals: for chart plot
      signals: buy/sell transaction for summary printing
    """
#----------------------------------------------
    buy_signals = [np.nan]
    sell_signals = [np.nan]
    signals = []
    last_signal = None
    for i in range(1, len(data)):
        if data['macd_hist'][i-1] < 0 and data['macd_hist'][i] > 0:
            price = (data['Open'][i] + data['Close'][i]) / 2
            buy_signals.append(price)
            last_signal = 'buy'
            signals.append({
                'date': data.index[i],
                'action': 'buy',
                'price': price
                })           
            sell_signals.append(np.nan)
        elif data['macd_hist'][i-1] > 0 and data['macd_hist'][i] < 0 and last_signal == 'buy':
            price = (data['Open'][i] + data['Close'][i]) / 2
            sell_signals.append(price)
            last_signal = 'sell'
            signals.append({
                'date': data.index[i],
                'action': 'sell',
                'price': price
                })           
            buy_signals.append(np.nan)
        else:
            buy_signals.append(np.nan)
            sell_signals.append(np.nan)
    return buy_signals, sell_signals, signals
#------------------------------------------------
# performance calculation
def print_performance_summary(signals):
    """Print buy/sell transactions and statistics
   
    Args:
      signals: recorded buy/sell transactions
    """
    pairs = zip(*[iter(signals)]*2)
    rows = []
    profit_count = 0
    profit_pct_avg = 0
    for (buy, sell) in pairs:
        profit = sell['price'] - buy['price']
        profit_pct = profit / buy['price']
        if profit > 0:
            profit_count += 1
        profit_pct_avg += profit_pct
        row = {
            'buy_date': buy['date'],
            'duration':  (sell['date'] - buy['date']).days,
            'profit': profit,
            'profit_pct': "{0:.2%}".format(profit_pct)
        }
        rows.append(row)
    df =  pd.DataFrame(rows, columns=['buy_date', 'duration',
                                      'profit', 'profit_pct'])
    with pd.option_context('display.max_rows', None, 'display.max_columns', None):
        print(df)
    total_transaction = math.floor(len(signals) / 2)
   
    stats = {
        'total_transaction': total_transaction,
        'profit_rate': "{0:.2%}".format(profit_count / total_transaction),
        'avg_profit_per_transaction': "{0:.2%}".format(profit_pct_avg / total_transaction)
    }
    for key, value in stats.items():
        print('{0:30}  {1}'.format(key, value))
#---------------------------------------------------
# buy/sell
buy_signals, sell_signals, signals = detect_macd_signals(data)
#---------------------------------------------------
# print buy/sell transaction and stats
print_performance_summary(signals)
# so sollte die performance Ausgabe aussehen
#                   buy_date  duration     profit profit_pct
#0 2022-09-12 00:00:00+02:00        14  -7.089996     -4.09%
#1 2022-10-10 00:00:00+02:00        49  40.110001     24.44%
#2 2023-01-04 00:00:00+01:00        26  12.724998      6.10%
#total_transaction               3
#profit_rate                     66.67%
#avg_profit_per_transaction      8.82%
#---------------------------------------------------
# plot buy/sell
buy_plot = mpf.make_addplot(buy_signals, type='scatter', marker='^',
                            markersize=50, panel=0)
sell_plot = mpf.make_addplot(sell_signals, type='scatter', marker='v',
                            markersize=50, panel=0)
#---------------------------------------------------
# plot candle chart and all
plots = [macd_plot, macd_signal_plot, macd_hist_plot, buy_plot, sell_plot]
mpf.plot(data, type='candle',figsize=(20,10), style='classic',
         addplot=plots, title=f"\n{symbol}", ylabel='Price (€)')

und so sieht der mit mplfinance erstelle chart von Allianz aus.

jetzt fehlt noch zum Vergleich (optimieren) anstatt macd crossover max(grün) und min(rot) von macd histogram als buy sell datzustellen. Pctap
Seiten: 1 2 3 4 5