Jump to content

Welcome to the new Traders Laboratory! Please bear with us as we finish the migration over the next few days. If you find any issues, want to leave feedback, get in touch with us, or offer suggestions please post to the Support forum here.

  • Welcome Guests

    Welcome. You are currently viewing the forum as a guest which does not give you access to all the great features at Traders Laboratory such as interacting with members, access to all forums, downloading attachments, and eligibility to win free giveaways. Registration is fast, simple and absolutely free. Create a FREE Traders Laboratory account here.

snowbird

Color Code MA for Range Bar Indicator

Recommended Posts

I'm stuck on what I thought would be a simple coding task for Uli's range bar expansion indicator.

 

My goal was to color code the two moving averages EMA34 and LSMA red and magenta respectively when slope is down; green and blue when slope is up. Full original code is posted below.

 

My attempt to color code EMA34 by it's slope (shown next) failed:

 

original plot line (17 lines from the end):

 

if plotEMA34 then plot1[1](EMA34[value1],"LBEMA34")

 

 

my failed code attempt (just turns MA green):

 

if plotema34 and

EMA34[value1] > EMA34[value1-1]then

plot1[1](EMA34[value1],"LBEMA34",Green)

else if

plotema34 and

EMA34[value1] < EMA34[value1-1]then

plot1[1](EMA34[value1],"LBEMA34",red);

 

I believe the problem has to do with the fact that this is built within an array.

Any savy coders able to lend some ideas?

 

Thanks in advance!,

snowbird

 

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

//Range Expansion Bars by Uli Schmuli

 

inputs: BarRange(3.75),

PlotRangeBars(true),

PlotExpansionBars(true),

PlotExpansionPotential(true),

BullBarColor(green),

BearBarColor(red),

RBThickness(3),

PlotEMA34(true),

PlotLSMA(true);

 

var:RangeHigh(0),

RangeLow(0),

RangeOpen(open),

RangeClose(0),

RBcolor(green),

LBLow(0),

LBHigh(0),

LBOpen(0),

LBClose(0),

offset(0),

LBxAvg(0),

SmoothingFactor(2/35),

LSMAtemp(0);

 

Array: EMA34[100](0),

RBHigh[100](close),

RBLow[100](close),

RBOpen[100](Close),

RBClose[100](close),

LSMA[100](close);

 

if barnumber = 1 then //1st bar initialization

 

begin

 

if range < BarRange then

begin

RangeHigh = high;

RangeLow = Low;

end;

 

if range > BarRange then

begin

RangeHigh = High;

RangeLow = Low;

end;

 

LSMA[1] = close;

EMA34[1] = close;

RBclose[1] = close;

LSMA[1] = close;

LBopen = open;

 

end else //all other bars

 

Begin

if date <> date[1] then //new day, begin new bar & close out prior bar

 

begin

LBHigh = RangeHigh;

LBlow = RangeLow;

LBOpen = RangeOpen;

LBclose = iff(close<RBclose[1],RangeLow,RangeHigh);

For Value1 = 100 downto 2

begin

 

EMA34[value1] = EMA34[value1-1];

RBHigh[value1] = RBHigh[Value1-1];

RBLow[value1] = RBLow[Value1-1];

RBOpen[value1] = RBOpen[Value1-1];

RBClose[value1] = RBClose[value1-1];

LSMA[value1] = LSMA[value1-1];

end;

 

RBHigh[1] = LBHigh;

RBLow[1] = LBLow;

RBOpen[1] = LBOpen;

RBClose[1] = LBClose;

 

EMA34[1] = EMA34[2] + SmoothingFactor * (RBclose[1] - EMA34[2]);

value1 = LinRegArray(RBClose,25, 0, value2, value3,value4, LSMAtemp);

LSMA[1] = LSMAtemp;

RangeOpen = Open;

RangeHigh = High;

RangeLow = low;

RangeClose = close;

offset = 1;

end;

 

if offset[1] = 1 and date = date[1] then offset = 0;

if low >= rangelow and high <= rangehigh then //Bar totally in barrange

begin

 

 

end;

 

if high > Rangehigh and low >= rangelow then //new high value

begin

 

 

rangehigh = high;

 

If high - rangelow > barrange then //New Higher bar detected

begin

LBlow = RangeLow;

LBHigh = RangeLow + BarRange;

LBOpen = RangeOpen;

LBclose = LBHigh;

For Value1 = 100 downto 2

begin

 

EMA34[value1] = EMA34[value1-1];

RBHigh[value1] = RBHigh[Value1-1];

RBLow[value1] = RBLow[Value1-1];

RBOpen[value1] = RBOpen[Value1-1];

RBClose[value1] = RBClose[value1-1];

LSMA[value1] = LSMA[value1-1];

end;

 

RBHigh[1] = LBHigh;

RBLow[1] = LBLow;

RBOpen[1] = LBOpen;

RBClose[1] = LBClose;

EMA34[1] = EMA34[2] + SmoothingFactor * (RBclose[1] - EMA34[2]);

value1 = LinRegArray(RBClose,25, 0, value2, value3,value4, LSMAtemp);

LSMA[1] = LSMAtemp;

 

rangeopen = Rangelow + barrange;

rangeLow = Rangelow + barrange;

RangeClose = rangeopen;

offset = 1;

end;

end;

 

if low < RangeLow and high <= rangehigh then//new low value

begin

Rangelow = low;

 

if rangehigh - low > barrange then //New lower bar detected

begin

LBHigh = RangeHigh;

LBlow = RangeHigh - barrange;

LBOpen = RangeOpen;

LBclose = LBlow;

For Value1 = 100 downto 2

begin

 

EMA34[value1] = EMA34[value1-1];

RBHigh[value1] = RBHigh[Value1-1];

RBLow[value1] = RBLow[Value1-1];

RBOpen[value1] = RBOpen[Value1-1];

RBClose[value1] = RBClose[value1-1];

LSMA[value1] = LSMA[value1-1];

end;

RBHigh[1] = LBHigh;

RBLow[1] = LBLow;

RBOpen[1] = LBOpen;

RBClose[1] = LBClose;

 

EMA34[1] = EMA34[2] + SmoothingFactor * (RBclose[1] - EMA34[2]);

value1 = LinRegArray(RBClose,25, 0, value2, value3,value4, LSMAtemp);

LSMA[1] = LSMAtemp;

 

RangeOpen = LBclose;

RangeHigh = LBclose;

RangeLow = low;

RangeClose = close;

offset = 1;

end;

end;

 

if high > RangeHigh and Low < RangeLow and rangehigh - rangelow > barrange then//engulfing bar

begin

RangeLow = low;

RangeHigh = high;

end;

end;

 

 

 

begin

 

if offset = 1 then //new bar begun

begin

 

if RBclose[1] < RBclose[2] then RBcolor = BearBarColor else RBcolor = BullBarColor;

plot15[1](RBHigh[value1],"RBHighL",RBColor,default,RBthickness);

plot16[1](RBLow[value1],"RBLowL",RBcolor,default,RBthickness);

plot17[1](RBopen[value1],"RBopenL",RBcolor,default,RBthickness);

Plot18[1](RBClose[value1],"RBcloseL",RBColor,default,RBthickness);

if plotEMA34 then plot1[1](EMA34[value1],"LBEMA34")

if plotLSMA then plot5[1](LSMA[Value1],"LSMA");

end;

 

if close < LBclose then RBcolor = darkred else RBcolor = darkgreen;

 

if PlotExpansionBars then

begin

plot20(rangehigh,"chigh",RBColor,default,1);

plot21(rangelow,"clow",RBcolor,default,1);

plot22(rangeopen,"copen",RBcolor,default,1);

Plot23(Close,"cclose",RBColor,default,1);

end;

 

if PlotExpansionPotential then

begin

Plot24(rangehigh-barrange,"PotLow");

Plot25(RangeLow+barrange,"PotHigh");

end;

 

end;

Share this post


Link to post
Share on other sites

you are making it way too complicated.

 

try this:

 

if plotema34 then
begin
plot1[1]( EMA34[value1], "LBEMA34");

if EMA34[value1] > EMA34[value1-1] then
SetPlotColor( 1, green )
else
SetPlotColor( 1, red );
end;

 

 

 

ps. I don't understand why you use plot1[1].

Share this post


Link to post
Share on other sites

Wow... quick response TAM's!!

 

I was definatly making it too hard (can you tell I'm NOT a coder)

 

but unfortunately the code simplification still does not work (I believe it has to do either with how often Uli samples the Array, or his smoothing algorithm in line #69

 

EMA34[1] = EMA34[2] + SmoothingFactor * (RBclose[1] - EMA34[2]);

 

Don't know if this will port to MT... but that's what it might take to figure this one out... I posted a chart that shows the MA color changes in the indicator with your code... never does go red... but we do get patches of green!

 

I do not know why Uli uses plot1[1]... but figured it had something to do with his array setup and calculations. If you eliminate the [1] then the MA just plots green (up and down!)

 

snowbird

rangeBarMA.thumb.jpg.b00511eeea8dfe654e09a37becf59d61.jpg

Share this post


Link to post
Share on other sites

maybe your array is not serial...

 

try this:

the var ema.34 should isolate the sequence.

 

 

var:
ema.34(0);

ema.34 = EMA34[value1];

if plotema34 then
begin
plot1[1]( EMA.34, "LBEMA34");

if EMA.34 > EMA.34[1] then
SetPlotColor( 1, green )
else
SetPlotColor( 1, red );
end;

Share this post


Link to post
Share on other sites
...I do not know why Uli uses plot1[1]... but figured it had something to do with his array setup and calculations. If you eliminate the [1] then the MA just plots green (up and down!)

 

snowbird

 

 

plot[1] ... plots the previous bar.

 

i.e. it goes back one bar to plot the color/value.

 

I don't know if he is changing the color/value of the previous bar? or simply skipping the plot on the current bar.

 

 

 

 

.

Edited by Tams

Share this post


Link to post
Share on other sites

The reason plot[1] is used for the range bar is because when using tick data input, you don't know if a bar is closed until the range has been exceeded on the next bar. So, if a range has been filled, then the proper place to plot the bar is one bar back.

 

You do realize that range bars are now one of the chart types that can be selected, yes? In other words, range bars are now part of the Tradestation platform. I wrote this code as a workaround until they released a version that included range bars.

 

While is may seem that with the native range bars in Tradestation that this code is now obsolete, it does have a useful purpose. If you are running a strategy using a range bar chart, you cannot use intrabar order generation. The code I provided allows you to take action within the current bar, effectively allowing you to generate orders & other actions "intrabar."

 

Also, I would like to draw your attention to an error in the code. A new bar generated by this code creates a range bar that has the same open value as the prior bar close. This is not correct. The open should be 1 tick above/below the prior bar close and the bar range calculated from there.

 

Uli

Share this post


Link to post
Share on other sites

Thanks Uli,

 

I'm actually using the range "Expansion" bars which are not available in tradestation.

 

You will probably laugh when you hear how I am using them... My major issue is patience and discipline (I tend to jump the gun too early and overtrade).

I've been using the range expansion bars in three ways to help:

 

1. Don't trade the chop (blue rectangle on chart, where you get an up/down/up sequence of expanded bars

 

2. Wait for a "signal" range expansion bar (each of the 3 green bars in a range downtrend on this chart are what I use as "signal" bars , and then I wait for a break below the low of the previous bar in this case to enter (3 yellow arrow trend re-entries on the chart)

 

3. But my favorites are the breakouts from consolidations. These are where significant time elapses between range expansion bars (green and red rectangles in the chart). I try and set the expansion factor at ~2x the ATR (been thinking about possible changes to the code to make this automatic!

 

I was also wondering what criteria you use for color coding bars between range expansion bars?

 

... and as you can see... I still have not completely figured out color coding of the EMA (issue is due to the smoothing algorithm I believe).

 

TAMS has been a great help as I now have portions that turn both red and green... its the parts in-between I'm missing!

 

Thanks again,

 

snowbird

Uli_range.thumb.jpg.d838034a47112db645649955bc8a7a56.jpg

Share this post


Link to post
Share on other sites
can someone post codes to plot point on an indicator i.e. CCI (2nd paragraph plotted with 133 tick as data1) to show Open of Range Expansion Bar.I am using MC.

 

 

can you post a mock up?

Share this post


Link to post
Share on other sites
Tams, what is mock and how i post it

 

a mock up is a hand drawn chart; a model to illustrate the position and format of your proposed plots.

 

for posting attachments:

when you are making reply to this post, look under the message box, you will see a section for Additional Options. Look for the "Manage Attachments" button

Share this post


Link to post
Share on other sites

Tams;

i have attched Mock . 2nd paragraph , ihave cci indicator valuecci = cci(ccilength)

circle shows cci value when LBclose and new bar begins. i wanted to plot those Point on cci when LBclose . !st paragraph has 233 tick chart as data1 and Range Expansion Bar indicator

(codes for that are posted in the begining of this topic.

Share this post


Link to post
Share on other sites

follwing codes ,modified from range expension bars code provided by

snowbird. I wanted to plot point when RB close. attached codes does it but not on top of cci. dots as shown in Mock , points plotted are not aligned on top of cci indicator.

can some one help tocorrect the codes so that points can be plotted on top of cci

 

//Range Expansion Bars by Uli Schmuli

 

inputs: BarRange(3.75),ccilen(14),

PlotRangeBars(true),

PlotExpansionBars(true),

PlotExpansionPotential(true),

BullBarColor(green),

BearBarColor(red),

RBThickness(3),

PlotEMA34(true),

PlotLSMA(true);

 

var:RangeHigh(0),

RangeLow(0),

RangeOpen(open),

RangeClose(0),

RBcolor(green),

LBLow(0),

LBHigh(0),

LBOpen(0),

LBClose(0),

offset(0),

LBxAvg(0),

SmoothingFactor(2/35),mycci(0),

LSMAtemp(0);

 

Array: EMA34[100](0),

RBHigh[100](close),

RBLow[100](close),

RBOpen[100](Close),

RBClose[100](close),

LSMA[100](close),

hvalue[100](0);

mycci = cci(ccilen);

if barnumber = 1 then //1st bar initialization

 

begin

 

if range < BarRange then

begin

RangeHigh = high;

RangeLow = Low;

end;

 

if range > BarRange then

begin

RangeHigh = High;

RangeLow = Low;

end;

hvalue[1] = mycci;

LSMA[1] = close;

EMA34[1] = close;

RBclose[1] = close;

LSMA[1] = close;

LBopen = open;

 

end else //all other bars

 

Begin

if date <> date[1] then //new day, begin new bar & close out prior bar

 

begin

LBHigh = RangeHigh;

LBlow = RangeLow;

LBOpen = RangeOpen;

LBclose = iff(close<RBclose[1],RangeLow,RangeHigh);

For Value1 = 100 downto 2

begin

hvalue[value1] = hvalue[value1-1];

EMA34[value1] = EMA34[value1-1];

RBHigh[value1] = RBHigh[Value1-1];

RBLow[value1] = RBLow[Value1-1];

RBOpen[value1] = RBOpen[Value1-1];

RBClose[value1] = RBClose[value1-1];

LSMA[value1] = LSMA[value1-1];

end;

 

RBHigh[1] = LBHigh;

RBLow[1] = LBLow;

RBOpen[1] = LBOpen;

RBClose[1] = LBClose;

hvalue[1] = mycci;

EMA34[1] = EMA34[2] + SmoothingFactor * (RBclose[1] - EMA34[2]);

value1 = LinRegArray(RBClose,25, 0, value2, value3,value4, LSMAtemp);

LSMA[1] = LSMAtemp;

RangeOpen = Open;

RangeHigh = High;

RangeLow = low;

RangeClose = close;

offset = 1;

end;

 

if offset[1] = 1 and date = date[1] then offset = 0;

if low >= rangelow and high <= rangehigh then //Bar totally in barrange

begin

 

 

end;

 

if high > Rangehigh and low >= rangelow then //new high value

begin

 

 

rangehigh = high;

 

If high - rangelow > barrange then //New Higher bar detected

begin

LBlow = RangeLow;

LBHigh = RangeLow + BarRange;

LBOpen = RangeOpen;

LBclose = LBHigh;

For Value1 = 100 downto 2

begin

hvalue[value1] = hvalue[value1-1];

EMA34[value1] = EMA34[value1-1];

RBHigh[value1] = RBHigh[Value1-1];

RBLow[value1] = RBLow[Value1-1];

RBOpen[value1] = RBOpen[Value1-1];

RBClose[value1] = RBClose[value1-1];

LSMA[value1] = LSMA[value1-1];

end;

hvalue[1] = mycci;

RBHigh[1] = LBHigh;

RBLow[1] = LBLow;

RBOpen[1] = LBOpen;

RBClose[1] = LBClose;

EMA34[1] = EMA34[2] + SmoothingFactor * (RBclose[1] - EMA34[2]);

value1 = LinRegArray(RBClose,25, 0, value2, value3,value4, LSMAtemp);

LSMA[1] = LSMAtemp;

 

rangeopen = Rangelow + barrange;

rangeLow = Rangelow + barrange;

RangeClose = rangeopen;

offset = 1;

end;

end;

 

if low < RangeLow and high <= rangehigh then//new low value

begin

Rangelow = low;

 

if rangehigh - low > barrange then //New lower bar detected

begin

LBHigh = RangeHigh;

LBlow = RangeHigh - barrange;

LBOpen = RangeOpen;

LBclose = LBlow;

For Value1 = 100 downto 2

begin

hvalue[value1] = hvalue[value1-1];

EMA34[value1] = EMA34[value1-1];

RBHigh[value1] = RBHigh[Value1-1];

RBLow[value1] = RBLow[Value1-1];

RBOpen[value1] = RBOpen[Value1-1];

RBClose[value1] = RBClose[value1-1];

LSMA[value1] = LSMA[value1-1];

end;

RBHigh[1] = LBHigh;

RBLow[1] = LBLow;

RBOpen[1] = LBOpen;

RBClose[1] = LBClose;

hvalue[1] = mycci;

EMA34[1] = EMA34[2] + SmoothingFactor * (RBclose[1] - EMA34[2]);

value1 = LinRegArray(RBClose,25, 0, value2, value3,value4, LSMAtemp);

LSMA[1] = LSMAtemp;

 

RangeOpen = LBclose;

RangeHigh = LBclose;

RangeLow = low;

RangeClose = close;

offset = 1;

end;

end;

 

if high > RangeHigh and Low < RangeLow and rangehigh - rangelow > barrange then//engulfing bar

begin

RangeLow = low;

RangeHigh = high;

end;

end;

 

 

 

begin

 

if offset = 1 then //new bar begun

begin

 

if RBclose[1] < RBclose[2] then RBcolor = BearBarColor else RBcolor = BullBarColor;

 

plot19[1](hvalue[value1],"ccpoint",RBcolor,default,RBThickness);

end;

 

 

 

 

 

end;

picture1.thumb.png.8fc471630d5e74b49ecb32686be2b66e.png

Share this post


Link to post
Share on other sites
follwing codes ,modified from range expension bars code provided by

snowbird. I wanted to plot point when RB close. attached codes does it but not on top of cci. dots as shown in Mock , points plotted are not aligned on top of cci indicator.

can some one help tocorrect the codes so that points can be plotted on top of cci

 

 

I am not sure if I understand what you mean/want.

 

you can put the mock up in the Paint program and add arrows/lines to point out to the specific place you are talking about... then add notes on the chart to describe the following:

 

1. what the code is doing now,

2. what you want the code to do.

3. what is triggering the "highlight" on the chart.

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Topics

  • Posts

    • re TikTok Recently metafakebook made what was apparently a move to stay aligned with ‘culture’ - no more fact ‘checking’, no more censorhip... basically ‘Zucker’ was shown that his mission was failing because they were only building profiles on ‘useful idiots’ instead of those who oppose the great centralization  (... just like long ago he only saw campus potential and had to be shown the promise and rewarded for fronting the great spyware and social engineering project called Fakebook)... ie they could have replaced him long ago In the same vein, who holds ‘title’ to tiktok doesn’t matter either... it will remain a spyware project regardless of who ‘buys’ it... and the data will forever be available to the CCP Just sayin’
    • Omobola,  As an engineer surely you have money to buy a ticket to Monterey, Mexico... just a hop and a jump from there to Texas...  hth zdo 
    • Date: 20th January 2025.   The NASDAQ Rises As Trump Inauguration Edges Closer!   US indices increased in value for the first time after struggling for 5 consecutive weeks. Of the main US indices the NASDAQ witnessed the strongest gains (4.12%). Risk indicators point to a higher risk appetite under the new US President, Donald Trump. President Trump's inauguration will take place this afternoon and has promised to sign over 100 consecutive orders within his first week. NASDAQ - Higher Investor Confidence! NASDAQ traders begin to stomach less frequent interest rate adjustments, the market turns its attention to earnings and Trump’s presidency. Investors are becoming more bullish under expectations that Trump will apply policies to support the US economy and entice further investment into the US stock market. A "risk-on" sentiment is evident in today's sessions, reflected in risk indicators like the VIX, High-Low Index, and Bond yields.     Investors this week will concentrate on two factors. The first factor is Trump’s consecutive orders which he has advised will be signed within his first week. Investors will closely monitor how and if these policies influence the US economy and stocks. The second factor is earnings season, which will start to gain momentum this week. Tomorrow, Netflix will release its quarterly earnings report after the market closes. Netflix is the NASDAQ’s 10th most influential company and 11th most impactful stock. Analysts expect the company’s earnings per share to drop from $5.40 to $4.21, but for Revenue to rise to $10.11 Billion. If Netflix is able to beat the earnings per share and revenue expectations, fundamental elections would indicate a rise in the price. Over the past 12 months the price has risen 76%. A further increase would further support the NASDAQ. Thereafter, investors will turn their attention to Intuitive Surgical’s earnings report. Currently, investors believe the company’s earnings per share and revenue will rise compared to the previous quarter. Intuitive’s stock has risen by more than 9% in the past week alone indicating that investors believe the company will continue to beat earnings expectations. The company has beat expectations over the past 12-months. How are Markets Reacting to Trump's inauguration? Trump pledged to issue executive orders aimed at advancing artificial intelligence programs and establishing the Department of Government Efficiency (Doge). Analysts expect these two alone to support US stocks. However, investors are not yet certain to what extent upcoming tariffs will pressure the NASDAQ and stocks. During the previous trade wars, the NASDAQ fell by 25% over a period of 4-months. Traders also should note that the NASDAQ rose in the 6-weeks after Trump won the elections. Over the past week, the VIX index fell by more than 12% indicating that the market believes US stocks will perform well under a Trump presidency. Simultaneously, US Bond yields have fallen from 4.80% to 4.58% which is known to positively influence the US stock market. Both the VIX and lower bond yields indicate higher investor confidence as Trump advises that policies will prompt more employment, US made products and more pro-US policies. NASDAQ - Technical Analysis The price of the NASDAQ trades above the 200-bar Moving Average on a 5-minute Chart indicating bullish price movement. Moving Averages have also crossed over upwards and the price trades above the VWAP indicating that the asset is maintaining its bullish momentum. Price action is also forming clear higher highs and higher lows, but investors will be cautious if the price does not find resistance at the $21,637 resistance level. In order to break above this level, investors will be hoping for positive earnings data from Netflix and Intuitive.     Key Takeaways: President Trump's inauguration will take place this afternoon with promise to sign over 100 consecutive orders within his first week. US indices rise after 5 weeks of declines, with the NASDAQ leading at 4.12%. Trump pledged to issue executive orders aimed at advancing artificial intelligence programs and establishing the Department of Government Efficiency. Analysts expect Netflix earnings per share to drop from $5.40 to $4.21, but for Revenue to rise to $10.11 Billion. Investors are becoming more bullish under expectations that President Trump will apply policies to support the US economy and entice further investment into the US stock market. Always trade with strict risk management. Your capital is the single most important aspect of your trading business.   Please note that times displayed based on local time zone and are from time of writing this report.   Click HERE to access the full HFM Economic calendar.   Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding of how markets work. Click HERE to register for FREE!   Click HERE to READ more Market news. Michalis Efthymiou HFMarkets Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in Leveraged Products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
    • Consider: some 80% of small to medium-sized businesses around the world don’t have a website.   Many businesses in emerging economies rely on social media platforms (e.g., WhatsApp, Facebook) as their primary digital presence instead of formal websites.   But even in more digitally advanced economies, the number can hover around half.   Why? Simple answer: although we’ve made it easier to make a website, it’s still not easy enough.   Let’s say a yoga instructor wants to offer online classes but lacks tech skills or a budget.   Instead of struggling with confusing platforms, she tells her AI agent, “Set up a website for me to host yoga classes.”   The AI handles everything.   It integrates Stripe for payments, Zoom for live classes, scheduling services for in-person classes, and a chat module for inquiries.   It even suggests templates.   When the instructor picks one and asks for a purple and white color scheme, the AI updates it instantly.   No coding. No frustration. Just results.   And the best part? She didn’t have to touch a single screen or key.   This is the future Wilson describes in Age of Invisible Machines.   And, as mentioned, it’s powered by three core technologies:   Conversational User Interfaces (CUIs): Say what you need; the system handles it. From building websites to booking flights, it’s fast and human-like.   Composable Architecture: Traditional business solutions become “modules”. Like LEGO bricks, modular tools—payments, chats, scheduling—snap together to create custom solutions without starting from scratch.   No-Code Programming: AI agents code for you, empowering anyone to create without needing a developer. It’s not just a better way to interact with technology…   It’s a complete reimagining of how industries operate.   As Harvard Business School’s Marco Iansiti says, “This isn’t disruption—it’s a fundamental shift in production and interaction.”   And, the thing is…   It’s not just possible. It’s already happening.   Early examples are already here. – Chris Campbell, AltucherConfidential Profits from free accurate cryptos signals: https://www.predictmag.com/ 
    • Question: My name is Omobola Sikiru from Lagos, Nigeria. I am mechanical engineering. Where can I find someone that can be my helper to relocate me to the USA?   Answer: According to your own profile, you are trying to enter other countries through deception and immigration fraud.   You are an engineer in Nigeria, but you are not licensed as an engineer in any other country.   There are no helpers, no sponsors, and nobody is going to give you money, get you an engineering job, or get you a visa.   You must qualify to immigrate. Nobody can help you with that.   Either you qualify and have settling in money, or you don’t.   You need to improve your English before trying to get a job in a Western, English speaking country. Engineers write reports. You wrote, ‘I am mechanical engineering’. Nobody will hire you if you write like this. Rathkeale Source: https://www.quora.com/My-name-is-Omobola-Sikiru-from-Lagos-Nigeria-I-am-mechanical-engineering-Where-can-I-find-someone-that-can-be-my-helper-to-relocate-me-to-the-USA   Profits from free accurate cryptos signals: https://www.predictmag.com/  
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.