{"id":53176,"date":"2020-07-21T09:47:00","date_gmt":"2020-07-21T13:47:00","guid":{"rendered":"https:\/\/ibkrcampus.com\/?p=53176"},"modified":"2022-11-21T09:45:54","modified_gmt":"2022-11-21T14:45:54","slug":"towards-better-keras-modeling-part-iv","status":"publish","type":"post","link":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/","title":{"rendered":"Towards Better Keras Modeling \u2013 Part IV"},"content":{"rendered":"\n<p><em>See the <a href=\"\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iii\/\">previous installment<\/a> in this series for Setup and Download<\/em>.<\/p>\n\n\n\n<p>TL;DR: essentially a talos workflow involves (1) creating a dict of parameter values to evaluate, (2) defining your keras model within a&nbsp;<code>build_model<\/code>&nbsp;as you may already do, but with a few small modifications in format, and (3) running a &#8220;Scan&#8221; method.<\/p>\n\n\n\n<p><em>Warning: the below code could take 60 minutes+ to execute. It took me about&nbsp;<strong>80 minutes on a Tesla K80 GPU<\/strong>. If you want to replicate results and are concerned about compute time, speed things up by:<\/em><\/p>\n\n\n\n<ol class=\"wp-block-list\"><li>reducing\/changing parameter values &#8211; especially&nbsp;<code>epoch<\/code>&nbsp;and&nbsp;<code>batch_size<\/code><\/li><li>setting the&nbsp;<code>grid_downsample<\/code>&nbsp;value to something less than 1.00 which runs a random subset of possible combinations, or<\/li><li>Adjusting the&nbsp;<code>early_stopper<\/code>&nbsp;settings (namely reducing the&nbsp;<code>patience<\/code>&nbsp;metric to cause the training to stop more quickly after low-water-mark is reached)<\/li><\/ol>\n\n\n\n<p><p style=\"background-color:#fcfcdb;font-size:11px\" class=\"has-background\">\n#from keras import models<br>\n#from keras import layers<br><br>\n\nfrom keras.models import Sequential<br>\nfrom keras.layers import Dropout, Dense<br>\nfrom keras.callbacks import TensorBoard<br>\nfrom talos.model.early_stopper import early_stopper<br><br>\n\n# track performance on tensorboard<br>\ntensorboard = TensorBoard(log_dir=&#8217;.\/logs&#8217;,<br>\n                 histogram_freq=0,batch_size=5000,<br>\n                 write_graph=False, <br>\n                 write_images=False)<br><br>\n\n\n# (1) Define dict of parameters to try<br>\np = {&#8216;first_neuron&#8217;:[10, 40, 160, 640, 1280],<br>\n     &#8216;hidden_neuron&#8217;:[10, 40, 160],<br>\n     &#8216;hidden_layers&#8217;:[0,1,2,4],<br>\n     &#8216;batch_size&#8217;: [1000,5000,10000],<br>\n     &#8216;optimizer&#8217;: [&#8216;adam&#8217;],<br>\n     &#8216;kernel_initializer&#8217;: [&#8216;uniform&#8217;], #&#8217;normal&#8217;<br>\n     &#8216;epochs&#8217;: [50],<br>\n     &#8216;dropout&#8217;: [0.0,0.25,0.5],<br>\n     &#8216;last_activation&#8217;: [&#8216;sigmoid&#8217;]}<br><br>\n\n# (2) create a function which constructs a compiled keras model object<br>\ndef numerai_model(x_train, y_train, x_val, y_val, params):<br>\n    print(params)<br><br>\n\n    model = Sequential()<br><br>\n    \n    \n    ## initial layer<br>\n    model.add(Dense(params[&#8216;first_neuron&#8217;], input_dim=x_train.shape[1],<br>\n                    activation=&#8217;relu&#8217;,<br>\n                    kernel_initializer = params[&#8216;kernel_initializer&#8217;] ))<br>\n    model.add(Dropout(params[&#8216;dropout&#8217;]))<br><br>\n    \n    ## hidden layers<br>\n    for i in range(params[&#8216;hidden_layers&#8217;]):<br>\n        print (f&#8221;adding layer {i+1}&#8221;)<br>\n        model.add(Dense(params[&#8216;hidden_neuron&#8217;], activation=&#8217;relu&#8217;,<br>\n                    kernel_initializer=params[&#8216;kernel_initializer&#8217;]))<br>\n        model.add(Dropout(params[&#8216;dropout&#8217;]))<br><br>\n    \n    \n    ## final layer<br>\n    model.add(Dense(1, activation=params[&#8216;last_activation&#8217;],<br>\n                    kernel_initializer=params[&#8216;kernel_initializer&#8217;]))<br><br>\n    \n    model.compile(loss=&#8217;binary_crossentropy&#8217;, <br>\n                  optimizer=params[&#8216;optimizer&#8217;],<br>\n                  metrics=[&#8216;acc&#8217;])<br><br>\n    \n    history = model.fit(x_train, y_train, <br>\n                        validation_data=[x_val, y_val],<br>\n                        batch_size=params[&#8216;batch_size&#8217;],<br>\n                        epochs=params[&#8216;epochs&#8217;],<br>\n                        callbacks=[tensorboard,early_stopper(params[&#8216;epochs&#8217;], patience=10)], #,ta.live(),<br>\n                        verbose=0)<br>\n    return history, model<br><br>\n\n# (3) Run a &#8220;Scan&#8221; using the params and function created above<br><br>\n\nt = ta.Scan(x=X_train.values,<br>\n            y=y_train.values,<br>\n            model=numerai_model,<br>\n            params=p,<br>\n            grid_downsample=0.50,<br>\n            dataset_name=&#8217;numerai_example&#8217;,<br>\n            experiment_no=&#8217;1&#8242;)\n<\/p><\/p>\n\n\n\n<p>Done! We now have results from 270 unique network configuration. Talos automatically saves them to a file named&nbsp;<code>[dataset_name]_[experiment_no].csv<\/code>&nbsp;which we can refer to offline. Hint: if you re-run, make sure to increment the&nbsp;<code>experiment_no<\/code>&nbsp;so you don&#8217;t overwrite past results.<\/p>\n\n\n\n<p><em>Visit <em>The Alpha Scientist blog<\/em> to download the complete code:<\/em><br><a href=\"https:\/\/alphascientist.com\/hyperparameter_optimization_with_talos.html\">https:\/\/alphascientist.com\/hyperparameter_optimization_with_talos.html<\/a><\/p>\n\n\n\n<p><em>The Alpha Scientist blog &#8211; Chad is a full-time quantitative trader who has been working on data analytics since before it was cool. He has long balanced his interest in computer science (MS in EE\/CS from MIT) with a fascination in markets (CFA designation in 2009). Prior to becoming a full-time quant, he built analytics products and managed teams at software companies across Silicon Valley.&nbsp;If you\u2019ve found this post useful, please follow&nbsp;<\/em><a href=\"https:\/\/twitter.com\/data2alpha\"><em>@data2alpha<\/em><\/a><em>&nbsp;on Twitter and forward to a friend or colleague who may also find this topic interesting.&nbsp;<\/em><a href=\"https:\/\/alphascientist.com\/\"><em>https:\/\/alphascientist.com\/<\/em><\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Join The Alpha Scientist for a coding session using talos &#8211; workflow involves (1) creating a dict of parameter values to evaluate, (2) defining your keras model within a build_model as you may already do, but with a few small modifications in format, and (3) running a &#8220;Scan&#8221; method.<\/p>\n","protected":false},"author":186,"featured_media":53216,"comment_status":"closed","ping_status":"open","sticky":true,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[339,343,349,338,341,352,344],"tags":[827,828,595,494,826],"contributors-categories":[13657],"class_list":{"0":"post-53176","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-data-science","8":"category-programing-languages","9":"category-python-development","10":"category-ibkr-quant-news","11":"category-quant-development","12":"category-quant-north-america","13":"category-quant-regions","14":"tag-keras","15":"tag-numerox","16":"tag-python","17":"tag-quant","18":"tag-talos","19":"contributors-categories-the-alpha-scientist"},"pp_statuses_selecting_workflow":false,"pp_workflow_action":"current","pp_status_selection":"publish","acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v26.9 (Yoast SEO v27.7) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>Towards Better Keras Modeling \u2013 Part IV | IBKR Quant<\/title>\n<meta name=\"description\" content=\"The Alpha Scientist codes talos - workflow involves (1) creating a dict of parameter values to evaluate, (2) defining your keras model within a...\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.interactivebrokers.com\/campus\/wp-json\/wp\/v2\/posts\/53176\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Towards Better Keras Modeling \u2013 Part IV | via IBKR Quant Blog\" \/>\n<meta property=\"og:description\" content=\"The Alpha Scientist codes talos - workflow involves (1) creating a dict of parameter values to evaluate, (2) defining your keras model within a build_model and (3) running a &quot;Scan&quot; method.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/\" \/>\n<meta property=\"og:site_name\" content=\"IBKR Campus US\" \/>\n<meta property=\"article:published_time\" content=\"2020-07-21T13:47:00+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2022-11-21T14:45:54+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/code-abstract.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"900\" \/>\n\t<meta property=\"og:image:height\" content=\"550\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"Contributor Author\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Contributor Author\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\n\t    \"@context\": \"https:\\\/\\\/schema.org\",\n\t    \"@graph\": [\n\t        {\n\t            \"@type\": \"NewsArticle\",\n\t            \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/towards-better-keras-modeling-part-iv\\\/#article\",\n\t            \"isPartOf\": {\n\t                \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/towards-better-keras-modeling-part-iv\\\/\"\n\t            },\n\t            \"author\": {\n\t                \"name\": \"Contributor Author\",\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#\\\/schema\\\/person\\\/e823e46b42ca381080387e794318a485\"\n\t            },\n\t            \"headline\": \"Towards Better Keras Modeling \u2013 Part IV\",\n\t            \"datePublished\": \"2020-07-21T13:47:00+00:00\",\n\t            \"dateModified\": \"2022-11-21T14:45:54+00:00\",\n\t            \"mainEntityOfPage\": {\n\t                \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/towards-better-keras-modeling-part-iv\\\/\"\n\t            },\n\t            \"wordCount\": 557,\n\t            \"publisher\": {\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#organization\"\n\t            },\n\t            \"image\": {\n\t                \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/towards-better-keras-modeling-part-iv\\\/#primaryimage\"\n\t            },\n\t            \"thumbnailUrl\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2020\\\/07\\\/code-abstract.jpg\",\n\t            \"keywords\": [\n\t                \"Keras\",\n\t                \"Numerox\",\n\t                \"Python\",\n\t                \"Quant\",\n\t                \"Talos\"\n\t            ],\n\t            \"articleSection\": [\n\t                \"Data Science\",\n\t                \"Programming Languages\",\n\t                \"Python Development\",\n\t                \"Quant\",\n\t                \"Quant Development\",\n\t                \"Quant North America\",\n\t                \"Quant Regions\"\n\t            ],\n\t            \"inLanguage\": \"en-US\"\n\t        },\n\t        {\n\t            \"@type\": \"WebPage\",\n\t            \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/towards-better-keras-modeling-part-iv\\\/\",\n\t            \"url\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/towards-better-keras-modeling-part-iv\\\/\",\n\t            \"name\": \"Towards Better Keras Modeling \u2013 Part IV | via IBKR Quant Blog\",\n\t            \"isPartOf\": {\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#website\"\n\t            },\n\t            \"primaryImageOfPage\": {\n\t                \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/towards-better-keras-modeling-part-iv\\\/#primaryimage\"\n\t            },\n\t            \"image\": {\n\t                \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/towards-better-keras-modeling-part-iv\\\/#primaryimage\"\n\t            },\n\t            \"thumbnailUrl\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2020\\\/07\\\/code-abstract.jpg\",\n\t            \"datePublished\": \"2020-07-21T13:47:00+00:00\",\n\t            \"dateModified\": \"2022-11-21T14:45:54+00:00\",\n\t            \"description\": \"The Alpha Scientist codes talos - workflow involves (1) creating a dict of parameter values to evaluate, (2) defining your keras model within a build_model and (3) running a \\\"Scan\\\" method.\",\n\t            \"inLanguage\": \"en-US\",\n\t            \"potentialAction\": [\n\t                {\n\t                    \"@type\": \"ReadAction\",\n\t                    \"target\": [\n\t                        \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/towards-better-keras-modeling-part-iv\\\/\"\n\t                    ]\n\t                }\n\t            ]\n\t        },\n\t        {\n\t            \"@type\": \"ImageObject\",\n\t            \"inLanguage\": \"en-US\",\n\t            \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/towards-better-keras-modeling-part-iv\\\/#primaryimage\",\n\t            \"url\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2020\\\/07\\\/code-abstract.jpg\",\n\t            \"contentUrl\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2020\\\/07\\\/code-abstract.jpg\",\n\t            \"width\": 900,\n\t            \"height\": 550,\n\t            \"caption\": \"Quant\"\n\t        },\n\t        {\n\t            \"@type\": \"WebSite\",\n\t            \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#website\",\n\t            \"url\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/\",\n\t            \"name\": \"IBKR Campus US\",\n\t            \"description\": \"Financial Education from Interactive Brokers\",\n\t            \"publisher\": {\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#organization\"\n\t            },\n\t            \"potentialAction\": [\n\t                {\n\t                    \"@type\": \"SearchAction\",\n\t                    \"target\": {\n\t                        \"@type\": \"EntryPoint\",\n\t                        \"urlTemplate\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/?s={search_term_string}\"\n\t                    },\n\t                    \"query-input\": {\n\t                        \"@type\": \"PropertyValueSpecification\",\n\t                        \"valueRequired\": true,\n\t                        \"valueName\": \"search_term_string\"\n\t                    }\n\t                }\n\t            ],\n\t            \"inLanguage\": \"en-US\"\n\t        },\n\t        {\n\t            \"@type\": \"Organization\",\n\t            \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#organization\",\n\t            \"name\": \"Interactive Brokers\",\n\t            \"alternateName\": \"IBKR\",\n\t            \"url\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/\",\n\t            \"logo\": {\n\t                \"@type\": \"ImageObject\",\n\t                \"inLanguage\": \"en-US\",\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#\\\/schema\\\/logo\\\/image\\\/\",\n\t                \"url\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2024\\\/05\\\/ibkr-campus-logo.jpg\",\n\t                \"contentUrl\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2024\\\/05\\\/ibkr-campus-logo.jpg\",\n\t                \"width\": 669,\n\t                \"height\": 669,\n\t                \"caption\": \"Interactive Brokers\"\n\t            },\n\t            \"image\": {\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#\\\/schema\\\/logo\\\/image\\\/\"\n\t            },\n\t            \"publishingPrinciples\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/about-ibkr-campus\\\/\",\n\t            \"ethicsPolicy\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/cyber-security-notice\\\/\"\n\t        },\n\t        {\n\t            \"@type\": \"Person\",\n\t            \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#\\\/schema\\\/person\\\/e823e46b42ca381080387e794318a485\",\n\t            \"name\": \"Contributor Author\",\n\t            \"url\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/author\\\/contributor-author\\\/\"\n\t        }\n\t    ]\n\t}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Towards Better Keras Modeling \u2013 Part IV | IBKR Quant","description":"The Alpha Scientist codes talos - workflow involves (1) creating a dict of parameter values to evaluate, (2) defining your keras model within a...","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.interactivebrokers.com\/campus\/wp-json\/wp\/v2\/posts\/53176\/","og_locale":"en_US","og_type":"article","og_title":"Towards Better Keras Modeling \u2013 Part IV | via IBKR Quant Blog","og_description":"The Alpha Scientist codes talos - workflow involves (1) creating a dict of parameter values to evaluate, (2) defining your keras model within a build_model and (3) running a \"Scan\" method.","og_url":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/","og_site_name":"IBKR Campus US","article_published_time":"2020-07-21T13:47:00+00:00","article_modified_time":"2022-11-21T14:45:54+00:00","og_image":[{"width":900,"height":550,"url":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/code-abstract.jpg","type":"image\/jpeg"}],"author":"Contributor Author","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Contributor Author","Est. reading time":"3 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"NewsArticle","@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/#article","isPartOf":{"@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/"},"author":{"name":"Contributor Author","@id":"https:\/\/ibkrcampus.com\/campus\/#\/schema\/person\/e823e46b42ca381080387e794318a485"},"headline":"Towards Better Keras Modeling \u2013 Part IV","datePublished":"2020-07-21T13:47:00+00:00","dateModified":"2022-11-21T14:45:54+00:00","mainEntityOfPage":{"@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/"},"wordCount":557,"publisher":{"@id":"https:\/\/ibkrcampus.com\/campus\/#organization"},"image":{"@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/#primaryimage"},"thumbnailUrl":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/code-abstract.jpg","keywords":["Keras","Numerox","Python","Quant","Talos"],"articleSection":["Data Science","Programming Languages","Python Development","Quant","Quant Development","Quant North America","Quant Regions"],"inLanguage":"en-US"},{"@type":"WebPage","@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/","url":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/","name":"Towards Better Keras Modeling \u2013 Part IV | via IBKR Quant Blog","isPartOf":{"@id":"https:\/\/ibkrcampus.com\/campus\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/#primaryimage"},"image":{"@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/#primaryimage"},"thumbnailUrl":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/code-abstract.jpg","datePublished":"2020-07-21T13:47:00+00:00","dateModified":"2022-11-21T14:45:54+00:00","description":"The Alpha Scientist codes talos - workflow involves (1) creating a dict of parameter values to evaluate, (2) defining your keras model within a build_model and (3) running a \"Scan\" method.","inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/towards-better-keras-modeling-part-iv\/#primaryimage","url":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/code-abstract.jpg","contentUrl":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/code-abstract.jpg","width":900,"height":550,"caption":"Quant"},{"@type":"WebSite","@id":"https:\/\/ibkrcampus.com\/campus\/#website","url":"https:\/\/ibkrcampus.com\/campus\/","name":"IBKR Campus US","description":"Financial Education from Interactive Brokers","publisher":{"@id":"https:\/\/ibkrcampus.com\/campus\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/ibkrcampus.com\/campus\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/ibkrcampus.com\/campus\/#organization","name":"Interactive Brokers","alternateName":"IBKR","url":"https:\/\/ibkrcampus.com\/campus\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/ibkrcampus.com\/campus\/#\/schema\/logo\/image\/","url":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2024\/05\/ibkr-campus-logo.jpg","contentUrl":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2024\/05\/ibkr-campus-logo.jpg","width":669,"height":669,"caption":"Interactive Brokers"},"image":{"@id":"https:\/\/ibkrcampus.com\/campus\/#\/schema\/logo\/image\/"},"publishingPrinciples":"https:\/\/www.interactivebrokers.com\/campus\/about-ibkr-campus\/","ethicsPolicy":"https:\/\/www.interactivebrokers.com\/campus\/cyber-security-notice\/"},{"@type":"Person","@id":"https:\/\/ibkrcampus.com\/campus\/#\/schema\/person\/e823e46b42ca381080387e794318a485","name":"Contributor Author","url":"https:\/\/www.interactivebrokers.com\/campus\/author\/contributor-author\/"}]}},"jetpack_featured_media_url":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/code-abstract.jpg","_links":{"self":[{"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/posts\/53176","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/users\/186"}],"replies":[{"embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/comments?post=53176"}],"version-history":[{"count":0,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/posts\/53176\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/media\/53216"}],"wp:attachment":[{"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/media?parent=53176"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/categories?post=53176"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/tags?post=53176"},{"taxonomy":"contributors-categories","embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/contributors-categories?post=53176"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}